@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600&display=swap');

body {
    background: #ffffff;
    color: #212529;
    font-family: 'Poppins', sans-serif;
}

.simple-nav .btn-link {
    color: #6c757d;
    padding-inline: 0.6rem;
}

.simple-nav .btn-link:hover {
    color: #212529;
}

.home-panel {
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.04);
}

.home-client-feature-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 14px;
}

.home-client-feature-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.home-client-feature-text {
    font-size: 0.95rem;
    line-height: 1.35;
}

.home-client-feature-action {
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .home-client-feature-item {
        flex-direction: column;
        align-items: flex-start;
    }
}

.lexware-start-card {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    padding: 32px;
}

.lexware-live-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-items: stretch;
}

.lexware-live-header {
    grid-column: 1 / -1;
}

.lexware-live-header h1 {
    margin: 0 0 12px;
    color: #000;
    font-size: 30px;
    font-weight: 400;
}

.lexware-live-column {
    margin: 0;
}

.lexware-start-intro {
    margin-bottom: 24px;
}

.lexware-start-form .mb-3:last-of-type {
    margin-bottom: 0.75rem !important;
}

.lexware-start-form .form-label {
    color: #000;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.04em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.lexware-start-form legend.col-form-label {
    color: #000;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.04em;
    margin-bottom: 8px;
    padding-top: 0;
    text-transform: uppercase;
}

.lexware-start-form .form-control,
.lexware-start-form .form-select {
    height: 48px;
    border: 1px solid #e6e6e6;
    border-radius: 4px;
    color: #000;
    font-size: 14px;
}

.lexware-start-form .form-control:focus,
.lexware-start-form .form-select:focus {
    border-color: #e3a14a;
    box-shadow: none;
}

.lexware-start-form .form-check + .form-check {
    margin-top: 12px;
}

.lexware-submit {
    width: auto;
    min-width: 180px;
    margin-top: 20px;
    padding-inline: 24px;
}

.lexware-live-progress h2 {
    margin-bottom: 0.5rem;
}

.lexware-terminal-log {
    background: #101218;
    color: #d6dde8;
    border-radius: 8px;
    border: 1px solid #2a3342;
    padding: 10px 12px;
    min-height: 220px;
    max-height: 360px;
    overflow: auto;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.8rem;
    line-height: 1.45;
}

.lexware-terminal-line {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
}

.lexware-terminal-time {
    color: #8ea1b8;
    margin-right: 8px;
}

.lexware-live-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.lexware-live-item {
    border: 1px solid #ececec;
    border-radius: 8px;
    padding: 10px 12px;
    background: #fcfcfc;
}

.lexware-live-item-wide {
    grid-column: 1 / -1;
}

.lexware-live-label {
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #6c757d;
    margin-bottom: 6px;
}

.lexware-live-value {
    font-size: 0.95rem;
    color: #212529;
    font-weight: 500;
}

.lexware-live-status-wrap {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-transform: capitalize;
}

.lexware-live-dot.is-idle {
    background: #adb5bd;
}

@media (max-width: 992px) {
    .lexware-live-layout {
        grid-template-columns: 1fr;
    }
}


.lexware-jobs-table td,
.lexware-jobs-table th {
    vertical-align: middle;
    height: 48px;
}

.lexware-jobs-table th {
    font-weight: 600;
    font-size: small;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.lexware-jobs-table .badge.text-bg-open-invoices {
    background-color: #fadec9 !important;
    color: #49290e;
}
.lexware-jobs-table .badge.text-bg-invoices {
    background-color: #fdecc8 !important;
    color: #49290e;
}
.lexware-jobs-table .badge.text-bg-line-items{
    background-color: #d3e5ef !important;
    color: #49290e;
}

.lexware-status-icon {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
}

.lexware-status-icon.is-queued {
    background: #6c757d;
}

/* Beanz Droid offcanvas should take about half the viewport */
#beanzDroidOffcanvas {
    --bs-offcanvas-width: 50vw;
}

@media (max-width: 768px) {
    #beanzDroidOffcanvas {
        --bs-offcanvas-width: 100vw;
    }
}

.b2b-invoicing-results table {
    font-size: 0.875rem;
}

.status-page-results table {
    font-size: 0.875rem;
}

.status-page-client .card {
    border-color: rgba(0, 0, 0, 0.08);
}

.status-page-badge {
    font-size: 0.8rem;
}

.status-page-openai {
    background: #f8f9fa;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
}

.status-page-status-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.status-page-job-card {
    border-color: rgba(0, 0, 0, 0.08);
    background: #fafafa;
}

.status-page-job-title {
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.status-page-client-details {
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
}

.status-page-client-summary {
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.status-page-client-summary::-webkit-details-marker {
    display: none;
}

.status-page-client-summary-title {
    font-size: 1.75rem;
    font-weight: 400;
    line-height: 1.2;
    color: #000;
}

.status-page-client-summary-caret {
    font-size: 1rem;
    transition: transform 0.2s ease;
}

.status-page-client-details[open] .status-page-client-summary-caret {
    transform: rotate(0deg);
}

.status-page-client-details:not([open]) .status-page-client-summary-caret {
    transform: rotate(-90deg);
}

.status-page-run-list {
    list-style: none;
    padding-left: 0;
    display: grid;
    gap: 0.35rem;
}

.status-page-latest-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    row-gap: 0.2rem;
    column-gap: 0.9rem;
}

.status-page-label {
    font-size: 0.73rem;
    font-weight: 500;
    color: #6c757d;
    letter-spacing: 0.03em;
}

.status-page-value {
    font-size: 1.02rem;
    font-weight: normal;
    color: #212529;
}

.status-page-value-sm {
    font-size: 0.92rem;
    font-weight: 600;
    color: #212529;
}

.status-page-divider {
    margin: 0.75rem 0;
    border-color: rgba(0, 0, 0, 0.22);
}

.status-page-status-line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
}

.status-page-previous-wrap {
    margin-top: 0.75rem;
}

.status-page-run-item {
    border: 1px solid rgba(0, 0, 0, 0.07);
    border-radius: 0.4rem;
    padding: 0.4rem 0.55rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.82rem;
    background: #efeff0;
}

.status-page-run-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.status-page-run-right {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    white-space: nowrap;
}

.status-page-run-importance {
    display: inline-flex;
    align-items: center;
}

.status-page-run-when {
    font-weight: normal;
    min-width: 0;
}

.status-page-run-badge {
    display: inline-flex;
    align-items: center;
}

.status-page-run-error {
    display: block;
}

.status-page-importance-badge {
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.01em;
}

.status-page-importance-none {
    color: #6c757d;
    font-size: 0.85rem;
}

.lexware-status-icon.is-running {
    background: #0dcaf0;
    animation: lexware-pulse 1.5s ease-in-out infinite;
}

.lexware-status-icon.is-completed {
    background: #198754;
}

.lexware-status-icon.is-completed-with-errors {
    background: #ffc107;
}

.lexware-status-icon.is-failed {
    background: #dc3545;
}

.lexware-status-icon.is-cancelled {
    background: #fd7e14;
}

.lexware-output-cell {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 260px;
}

.lexware-output-name {
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    font-size: 0.875rem;
}

.lexware-output-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.lexware-icon-btn {
    display: inline-flex;
    width: 20px;
    height: 20px;
    color: #6c757d;
    text-decoration: none;
}

.lexware-icon-btn:hover {
    color: #212529;
}

.lexware-icon-btn i {
    width: 100%;
    height: 100%;
    font-size: 1rem;
    line-height: 1;
}

.lexware-icon-btn.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

@keyframes lexware-pulse {
    0% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(13, 202, 240, 0.5);
    }
    70% {
        transform: scale(1.08);
        box-shadow: 0 0 0 8px rgba(13, 202, 240, 0);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(13, 202, 240, 0);
    }
}

/* Lexware visualization page */
.lexware-visualize-header .letter-spacing {
    letter-spacing: 0.04em;
}

.lexware-visualize-filters .form-label {
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #6c757d;
}

.lexware-visualize-summary .lexware-summary-label {
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #6c757d;
    margin-bottom: 4px;
}

.lexware-visualize-summary .lexware-summary-value {
    font-size: 1.5rem;
    font-weight: 600;
}

.lexware-visualize-table .letter-spacing {
    letter-spacing: 0.04em;
}

.lexware-visualize-table-data td,
.lexware-visualize-table-data th {
    vertical-align: middle;
}

.lexware-visualize-table-data th {
    font-weight: 600;
    font-size: small;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.lexware-visualize-table-data .text-end {
    font-variant-numeric: tabular-nums;
}

/* Sortable column headers */
.lexware-sortable {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}

.lexware-sortable:hover {
    color: var(--bs-primary, #0d6efd);
}

.lexware-sort-icon {
    font-size: 0.75em;
    opacity: 0.7;
}

/* Click-to-filter client name */
.lexware-filter-client {
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.lexware-filter-client:hover {
    color: var(--bs-primary, #0d6efd);
}

/* Invoice status badges (all invoices visualization) */
.lexware-status-badge {
    font-size: 0.7rem;
    font-weight: 500;
}

.lexware-status-open {
    background-color: #fadec9;
    color: #49290e;
}

.lexware-status-paid,
.lexware-status-paidoff {
    background-color: #d4edda;
    color: #155724;
}

.lexware-status-voided {
    background-color: #f8d7da;
    color: #721c24;
}

.lexware-status-transferred {
    background-color: #d3e5ef;
    color: #49290e;
}

.lexware-status-draft {
    background-color: #e2e3e5;
    color: #383d41;
}
