:root {
    --servora-bg: #07111c;
    --servora-bg-soft: #0d1826;
    --servora-panel: #111c2a;
    --servora-panel-2: #162233;
    --servora-border: rgba(255, 255, 255, 0.08);
    --servora-text: #f6f8fb;
    --servora-text-soft: #98a6b8;
    --servora-text-muted: #7f8ca3;
    --servora-accent: #e02424;
    --servora-accent-soft: rgba(224, 36, 36, 0.16);
    --servora-success: #49c26b;
    --servora-warning: #f0ba2d;
    --servora-orange: #f08b2d;
}

.servora-marketing-page {
    margin: 0;
    background: #f6f8fb;
    color: #111827;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    letter-spacing: 0;
}

.servora-marketing-page * {
    box-sizing: border-box;
}

.servora-marketing-page a {
    color: inherit;
    text-decoration: none;
}

.servora-marketing-nav {
    position: sticky;
    top: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 1.5rem;
    align-items: center;
    width: min(1180px, calc(100% - 2rem));
    margin: 0 auto;
    padding: 1rem 0;
    background: rgba(246, 248, 251, 0.86);
    backdrop-filter: blur(18px);
}

.servora-marketing-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.servora-marketing-brand-mark {
    display: grid;
    place-items: center;
    width: 3rem;
    height: 3rem;
    border-radius: 0.9rem;
    background: #e02424;
    color: #ffffff;
    font-size: 1.35rem;
    font-weight: 900;
    box-shadow: 0 18px 34px rgba(224, 36, 36, 0.26);
}

.servora-marketing-brand strong,
.servora-marketing-brand small {
    display: block;
    line-height: 1.05;
}

.servora-marketing-brand strong {
    color: #111827;
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: 0;
}

.servora-marketing-brand small {
    margin-top: 0.22rem;
    color: #64748b;
    font-size: 0.77rem;
    font-weight: 750;
}

.servora-marketing-links {
    display: flex;
    justify-content: center;
    gap: 1.4rem;
    color: #475569;
    font-size: 0.94rem;
    font-weight: 750;
}

.servora-marketing-links a:hover {
    color: #e02424;
}

.servora-marketing-actions,
.servora-marketing-cta-row,
.servora-marketing-final-actions {
    display: flex;
    align-items: center;
    gap: 0.7rem;
}

.servora-marketing-link-button,
.servora-marketing-secondary-button,
.servora-marketing-primary-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0.75rem 1rem;
    border-radius: 0.55rem;
    font-weight: 850;
    line-height: 1;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.servora-marketing-primary-button {
    border: 1px solid #e02424;
    background: #e02424;
    color: #ffffff;
    box-shadow: 0 18px 34px rgba(224, 36, 36, 0.24);
}

.servora-marketing-primary-button:hover {
    color: #ffffff;
    background: #c91f1f;
    border-color: #c91f1f;
    transform: translateY(-1px);
}

.servora-marketing-primary-button.is-large,
.servora-marketing-secondary-button {
    min-height: 3.15rem;
    padding-inline: 1.15rem;
}

.servora-marketing-link-button,
.servora-marketing-secondary-button {
    border: 1px solid rgba(15, 23, 42, 0.14);
    background: rgba(255, 255, 255, 0.72);
    color: #111827;
}

.servora-marketing-link-button:hover,
.servora-marketing-secondary-button:hover {
    border-color: rgba(224, 36, 36, 0.42);
    color: #b91c1c;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.servora-marketing-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(440px, 1.08fr);
    gap: 2.2rem;
    align-items: center;
    width: min(1180px, calc(100% - 2rem));
    min-height: 670px;
    margin: 0 auto;
    padding: 4.7rem 0 3.8rem;
}

.servora-marketing-kicker,
.servora-marketing-section-head span,
.servora-marketing-final span {
    color: #0f766e;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.servora-marketing-hero h1 {
    margin: 1rem 0 1.15rem;
    color: #0f172a;
    font-size: clamp(3.4rem, 8vw, 7.3rem);
    font-weight: 900;
    line-height: 0.9;
}

.servora-marketing-hero p {
    max-width: 39rem;
    margin: 0;
    color: #475569;
    font-size: clamp(1.08rem, 2vw, 1.35rem);
    font-weight: 550;
    line-height: 1.62;
}

.servora-marketing-cta-row {
    flex-wrap: wrap;
    margin-top: 1.8rem;
}

.servora-marketing-trust-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 1.45rem;
}

.servora-marketing-trust-row span {
    display: inline-flex;
    align-items: center;
    min-height: 2.15rem;
    padding: 0.45rem 0.72rem;
    border: 1px solid rgba(15, 118, 110, 0.16);
    border-radius: 0.5rem;
    background: #ffffff;
    color: #0f766e;
    font-size: 0.82rem;
    font-weight: 850;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.05);
}

.servora-marketing-product-visual {
    min-width: 0;
}

.servora-product-window {
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 1rem;
    background: #0b1220;
    box-shadow: 0 34px 86px rgba(15, 23, 42, 0.24);
}

.servora-product-window-bar {
    display: flex;
    align-items: center;
    gap: 0.42rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    background: #111827;
}

.servora-product-window-bar span {
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 999px;
    background: #e02424;
}

.servora-product-window-bar span:nth-child(2) {
    background: #f59e0b;
}

.servora-product-window-bar span:nth-child(3) {
    background: #10b981;
}

.servora-product-window-bar strong {
    margin-left: 0.5rem;
    color: #cbd5e1;
    font-size: 0.82rem;
}

.servora-product-shell {
    display: grid;
    grid-template-columns: 10rem minmax(0, 1fr);
    min-height: 430px;
}

.servora-product-shell aside {
    display: grid;
    align-content: start;
    gap: 0.55rem;
    padding: 1.15rem;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    background: #0f172a;
}

.servora-product-logo {
    display: grid;
    place-items: center;
    width: 2.65rem;
    height: 2.65rem;
    margin-bottom: 0.85rem;
    border-radius: 0.78rem;
    background: #e02424;
    color: #ffffff;
    font-weight: 900;
}

.servora-product-shell aside span {
    display: block;
    padding: 0.72rem 0.75rem;
    border-radius: 0.55rem;
    color: #94a3b8;
    font-size: 0.78rem;
    font-weight: 800;
}

.servora-product-shell aside span.is-active {
    background: rgba(224, 36, 36, 0.16);
    color: #ffffff;
}

.servora-product-shell section {
    display: grid;
    gap: 1rem;
    align-content: start;
    padding: 1.25rem;
    background:
        linear-gradient(135deg, rgba(224, 36, 36, 0.14), transparent 42%),
        #0b1220;
}

.servora-product-topline {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
}

.servora-product-topline small,
.servora-product-board span,
.servora-product-board small,
.servora-product-stats span {
    display: block;
    color: #94a3b8;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.servora-product-topline strong {
    display: block;
    margin-top: 0.15rem;
    color: #ffffff;
    font-size: 1.3rem;
}

.servora-product-topline button {
    border: 0;
    border-radius: 0.55rem;
    background: #e02424;
    color: #ffffff;
    font-size: 0.82rem;
    font-weight: 850;
    padding: 0.72rem 0.9rem;
}

.servora-product-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-product-stats div,
.servora-product-board div {
    border: 1px solid rgba(148, 163, 184, 0.13);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.045);
}

.servora-product-stats div {
    padding: 0.85rem;
}

.servora-product-stats strong {
    display: block;
    margin-top: 0.55rem;
    color: #ffffff;
    font-size: 1.35rem;
}

.servora-product-board {
    display: grid;
    gap: 0.7rem;
}

.servora-product-board div {
    display: grid;
    gap: 0.28rem;
    padding: 0.9rem;
}

.servora-product-board strong {
    color: #f8fafc;
    font-size: 0.96rem;
}

.servora-marketing-section,
.servora-marketing-final {
    width: min(1180px, calc(100% - 2rem));
    margin: 0 auto;
}

.servora-marketing-section {
    padding: 4.4rem 0;
}

.servora-marketing-section-head {
    max-width: 48rem;
    margin-bottom: 1.7rem;
}

.servora-marketing-section-head h2,
.servora-marketing-final h2 {
    margin: 0.55rem 0 0;
    color: #0f172a;
    font-size: clamp(2rem, 4vw, 3.3rem);
    font-weight: 920;
    line-height: 1.02;
}

.servora-marketing-section-head p {
    margin: 0.85rem 0 0;
    color: #64748b;
    font-size: 1.05rem;
    font-weight: 550;
    line-height: 1.6;
}

.servora-marketing-module-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.95rem;
}

.servora-marketing-module-grid article,
.servora-marketing-flow div,
.servora-marketing-final {
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 0.9rem;
    background: #ffffff;
    box-shadow: 0 16px 42px rgba(15, 23, 42, 0.06);
}

.servora-marketing-module-grid article {
    display: grid;
    gap: 0.75rem;
    align-content: start;
    min-height: 14.2rem;
    padding: 1.15rem;
}

.servora-module-icon {
    display: grid;
    place-items: center;
    width: 2.55rem;
    height: 2.55rem;
    border-radius: 0.65rem;
    background: #ecfeff;
    color: #0f766e;
    font-size: 0.8rem;
    font-weight: 900;
}

.servora-marketing-module-grid h3,
.servora-marketing-flow h3 {
    margin: 0;
    color: #111827;
    font-size: 1.18rem;
    font-weight: 900;
}

.servora-marketing-module-grid p,
.servora-marketing-flow p {
    margin: 0;
    color: #64748b;
    font-size: 0.96rem;
    font-weight: 520;
    line-height: 1.55;
}

.servora-marketing-flow-section {
    padding-top: 2rem;
}

.servora-marketing-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.servora-marketing-flow div {
    display: grid;
    gap: 0.65rem;
    padding: 1.1rem;
}

.servora-marketing-flow strong {
    display: grid;
    place-items: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    background: #fee2e2;
    color: #b91c1c;
    font-weight: 900;
}

.servora-marketing-final {
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    align-items: center;
    margin-bottom: 4rem;
    padding: 1.55rem;
}

.servora-marketing-final h2 {
    max-width: 48rem;
    font-size: clamp(1.65rem, 3vw, 2.55rem);
}

@media (max-width: 1040px) {
    .servora-marketing-nav {
        grid-template-columns: 1fr auto;
    }

    .servora-marketing-links {
        display: none;
    }

    .servora-marketing-hero {
        grid-template-columns: 1fr;
        min-height: 0;
        padding-top: 3rem;
    }

    .servora-marketing-module-grid,
    .servora-marketing-flow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .servora-marketing-nav {
        width: min(100% - 1.25rem, 1180px);
        grid-template-columns: 1fr;
        padding-block: 0.8rem;
    }

    .servora-marketing-actions {
        width: 100%;
    }

    .servora-marketing-actions > * {
        flex: 1;
    }

    .servora-marketing-hero,
    .servora-marketing-section,
    .servora-marketing-final {
        width: min(100% - 1.25rem, 1180px);
    }

    .servora-marketing-hero {
        gap: 1.5rem;
        padding: 2rem 0 2.6rem;
    }

    .servora-marketing-hero h1 {
        font-size: clamp(3rem, 18vw, 4.7rem);
    }

    .servora-marketing-hero p {
        font-size: 1rem;
    }

    .servora-marketing-cta-row,
    .servora-marketing-final,
    .servora-marketing-final-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .servora-marketing-cta-row > *,
    .servora-marketing-final-actions > * {
        width: 100%;
    }

    .servora-product-shell {
        grid-template-columns: 1fr;
    }

    .servora-product-shell aside {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }

    .servora-product-logo {
        display: none;
    }

    .servora-product-shell aside span {
        padding: 0.62rem 0.55rem;
        text-align: center;
    }

    .servora-product-stats,
    .servora-marketing-module-grid,
    .servora-marketing-flow {
        grid-template-columns: 1fr;
    }
}

.servora-calendar-filter {
    display: grid;
    grid-template-columns: minmax(10rem, 0.25fr) minmax(10rem, 0.25fr) minmax(14rem, 1fr) auto;
    gap: 0.9rem;
    align-items: end;
}

.servora-calendar-filter > * {
    min-width: 0;
}

.servora-calendar-filter-actions {
    display: flex;
    gap: 0.55rem;
}

.servora-calendar-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.34fr);
    gap: 1rem;
    align-items: start;
}

.servora-calendar-main {
    min-width: 0;
}

.servora-calendar-head {
    align-items: center;
    gap: 1rem;
}

.servora-calendar-head p {
    margin: 0.2rem 0 0;
    color: var(--servora-text-soft);
}

.servora-calendar-week-strip {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.65rem;
    margin-bottom: 1rem;
}

.servora-calendar-week-day {
    display: grid;
    gap: 0.2rem;
    min-height: 5.4rem;
    padding: 0.75rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
    transition: border-color 0.16s ease, background 0.16s ease, transform 0.16s ease;
}

.servora-calendar-week-day:hover {
    border-color: rgba(255, 59, 48, 0.42);
    color: var(--servora-text);
    transform: translateY(-1px);
}

.servora-calendar-week-day span,
.servora-calendar-week-day small,
.servora-calendar-week-label {
    color: var(--servora-text-muted);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-calendar-week-day strong {
    font-size: 1.45rem;
    line-height: 1;
}

.servora-calendar-week-day.is-selected,
.servora-calendar-day.is-selected {
    border-color: rgba(255, 59, 48, 0.65);
    background: linear-gradient(180deg, rgba(255, 59, 48, 0.16), rgba(255, 59, 48, 0.06));
    box-shadow: inset 0 0 0 1px rgba(255, 59, 48, 0.18);
}

.servora-calendar-week-day.is-today:not(.is-selected),
.servora-calendar-day.is-today:not(.is-selected) {
    border-color: rgba(59, 130, 246, 0.48);
}

.servora-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.6rem;
}

.servora-calendar-week-label {
    padding: 0 0.2rem;
    text-align: center;
}

.servora-calendar-day {
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 0.65rem;
    min-height: 9.2rem;
    padding: 0.75rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
    color: var(--servora-text);
    text-decoration: none;
    overflow: hidden;
    transition: border-color 0.16s ease, background 0.16s ease;
}

.servora-calendar-day:hover {
    border-color: rgba(255, 59, 48, 0.42);
    color: var(--servora-text);
    background: rgba(255, 255, 255, 0.05);
}

.servora-calendar-day.is-muted {
    opacity: 0.45;
}

.servora-calendar-day-number {
    display: inline-flex;
    width: 1.9rem;
    height: 1.9rem;
    align-items: center;
    justify-content: center;
    border-radius: 0.6rem;
    color: var(--servora-text);
    font-weight: 800;
}

.servora-calendar-day.is-today .servora-calendar-day-number {
    background: rgba(59, 130, 246, 0.16);
    color: #60a5fa;
}

.servora-calendar-day.is-selected .servora-calendar-day-number {
    background: #ff3b30;
    color: #ffffff;
}

.servora-calendar-day-events {
    display: grid;
    align-content: start;
    gap: 0.35rem;
    min-width: 0;
}

.servora-calendar-event-pill,
.servora-calendar-more {
    display: block;
    min-width: 0;
    padding: 0.32rem 0.45rem;
    border-radius: 0.55rem;
    background: rgba(255, 59, 48, 0.11);
    color: var(--servora-text);
    font-size: 0.78rem;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-event-pill b {
    color: #ff8a82;
    margin-right: 0.25rem;
}

.servora-calendar-time-chip {
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-items: center;
    gap: 0.35rem;
    padding: 0.24rem 0.42rem;
    border: 1px solid rgba(59, 130, 246, 0.28);
    border-radius: 999px;
    background: rgba(59, 130, 246, 0.13);
    color: #bfdbfe;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
}

.servora-calendar-time-chip b,
.servora-calendar-time-chip span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.servora-calendar-time-chip b {
    color: #93c5fd;
}

.servora-calendar-more {
    background: rgba(148, 163, 184, 0.13);
    color: var(--servora-text-soft);
    font-weight: 700;
}

.servora-calendar-side {
    display: grid;
    gap: 1rem;
    min-width: 0;
}

.servora-calendar-agenda,
.servora-calendar-upcoming {
    display: grid;
    gap: 0.7rem;
}

.servora-calendar-agenda-item {
    display: grid;
    grid-template-columns: 3.3rem minmax(0, 1fr);
    gap: 0.75rem;
    align-items: start;
    padding: 0.75rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-calendar-agenda-item:hover {
    border-color: rgba(255, 59, 48, 0.42);
    color: var(--servora-text);
}

.servora-calendar-agenda-item time {
    display: inline-flex;
    width: 3.3rem;
    height: 2.15rem;
    align-items: center;
    justify-content: center;
    border-radius: 0.65rem;
    background: rgba(255, 59, 48, 0.13);
    color: #ff8a82;
    font-weight: 800;
}

.servora-calendar-agenda-item span {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
}

.servora-calendar-agenda-item strong,
.servora-calendar-agenda-item small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-agenda-item small {
    color: var(--servora-text-soft);
}

.servora-calendar-agenda-item .badge {
    grid-column: 2;
    justify-self: start;
    font-style: normal;
}

body.servora-body.theme-light .servora-calendar-week-day,
body.servora-body.theme-light .servora-calendar-day,
body.servora-body.theme-light .servora-calendar-agenda-item {
    background: rgba(15, 23, 42, 0.025);
}

body.servora-body.theme-light .servora-calendar-event-pill {
    background: rgba(255, 59, 48, 0.09);
}

.servora-calendar-app {
    display: grid;
    grid-template-columns: minmax(18rem, 0.28fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

[data-calendar-live-root] {
    transition: opacity 0.14s ease, transform 0.14s ease;
}

[data-calendar-live-root].is-calendar-loading {
    opacity: 0.62;
    transform: translateY(1px);
    pointer-events: none;
}

.servora-calendar-info {
    display: grid;
    gap: 1rem;
    min-width: 0;
}

.servora-calendar-info-head {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.servora-calendar-info-head h2 {
    margin: 0;
    font-size: 1.2rem;
}

.servora-calendar-info-head p,
.servora-calendar-period p {
    margin: 0.2rem 0 0;
    color: var(--servora-text-soft);
}

.servora-calendar-icon {
    display: inline-flex;
    width: 2.7rem;
    height: 2.7rem;
    align-items: center;
    justify-content: center;
    border-radius: 0.85rem;
    background: linear-gradient(135deg, #ff3b30, #b91c1c);
    color: #ffffff;
    box-shadow: 0 14px 28px rgba(255, 59, 48, 0.22);
}

.servora-calendar-mini-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(5.8rem, 1fr));
    gap: 0.55rem;
    margin-bottom: 1rem;
}

.servora-calendar-mini-stats div {
    padding: 0.75rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-calendar-mini-stats span {
    display: block;
    color: var(--servora-text-muted);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-calendar-mini-stats strong {
    display: block;
    margin-top: 0.25rem;
    font-size: 1.35rem;
    line-height: 1;
}

.servora-calendar-side-filter {
    display: grid;
    gap: 0.85rem;
}

.servora-calendar-layer-box {
    display: grid;
    gap: 0.45rem;
    padding: 0.85rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-calendar-layer-box .form-label {
    margin-bottom: 0.15rem;
}

.servora-calendar-layer-box .form-check {
    margin: 0;
}

.servora-calendar-board {
    min-width: 0;
}

.servora-calendar-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.servora-calendar-period {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
}

.servora-calendar-period > div {
    min-width: 0;
}

.servora-calendar-period .card-title,
.servora-calendar-period p {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-nav {
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--servora-border);
    border-radius: 0.65rem;
    background: rgba(255, 255, 255, 0.045);
    color: var(--servora-text);
}

.servora-calendar-nav:hover {
    border-color: rgba(255, 59, 48, 0.42);
    color: var(--servora-text);
}

.servora-calendar-view-switch {
    display: inline-flex;
    flex: 0 0 auto;
    overflow: hidden;
    border: 1px solid var(--servora-border);
    border-radius: 0.7rem;
    background: rgba(255, 255, 255, 0.045);
}

.servora-calendar-view-switch a {
    min-width: 4.4rem;
    padding: 0.6rem 0.85rem;
    color: var(--servora-text-soft);
    font-weight: 800;
    text-align: center;
    text-decoration: none;
}

.servora-calendar-view-switch a.active {
    background: linear-gradient(135deg, rgba(255, 59, 48, 0.28), rgba(255, 59, 48, 0.12));
    color: #ffffff;
}

.servora-calendar-month-grid,
.servora-calendar-week-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.55rem;
}

.servora-calendar-month-grid .servora-calendar-week-label {
    padding: 0.15rem 0.2rem 0.35rem;
}

.servora-calendar-week-grid {
    grid-template-columns: 4.4rem repeat(7, minmax(8.5rem, 1fr));
    gap: 0;
    overflow-x: auto;
}

.servora-calendar-time-corner,
.servora-calendar-week-head,
.servora-calendar-hour,
.servora-calendar-week-slot {
    border-right: 1px solid var(--servora-border);
    border-bottom: 1px solid var(--servora-border);
}

.servora-calendar-time-corner {
    position: sticky;
    left: 0;
    z-index: 2;
    min-height: 4.9rem;
    background: var(--servora-panel);
    border-top: 1px solid var(--servora-border);
    border-left: 1px solid var(--servora-border);
    border-radius: 0.8rem 0 0 0;
}

.servora-calendar-week-head {
    display: grid;
    gap: 0.2rem;
    min-height: 4.9rem;
    padding: 0.7rem;
    border-top: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-calendar-week-head:last-of-type {
    border-radius: 0 0.8rem 0 0;
}

.servora-calendar-week-head:hover {
    background: rgba(255, 59, 48, 0.08);
    color: var(--servora-text);
}

.servora-calendar-week-head span,
.servora-calendar-week-head small,
.servora-calendar-week-head em {
    color: var(--servora-text-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-calendar-week-head em {
    display: block;
    min-width: 0;
    padding: 0.2rem 0.35rem;
    border-radius: 0.45rem;
    background: rgba(245, 158, 11, 0.13);
    color: #fbbf24;
    font-style: normal;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-week-head strong {
    font-size: 1.35rem;
    line-height: 1;
}

.servora-calendar-week-head.is-selected,
.servora-calendar-week-slot.is-today {
    background: rgba(255, 59, 48, 0.07);
}

.servora-calendar-week-head.is-today strong {
    color: #60a5fa;
}

.servora-calendar-hour {
    position: sticky;
    left: 0;
    z-index: 1;
    display: flex;
    min-height: 5.2rem;
    align-items: flex-start;
    justify-content: center;
    padding-top: 0.8rem;
    border-left: 1px solid var(--servora-border);
    background: var(--servora-panel);
    color: var(--servora-text-muted);
    font-size: 0.76rem;
    font-weight: 800;
}

.servora-calendar-week-slot {
    min-height: 5.2rem;
    padding: 0.35rem;
    background: rgba(255, 255, 255, 0.018);
}

.servora-calendar-block {
    display: grid;
    gap: 0.08rem;
    margin-bottom: 0.32rem;
    padding: 0.45rem 0.5rem;
    border-radius: 0.55rem;
    background: linear-gradient(135deg, rgba(255, 59, 48, 0.24), rgba(255, 59, 48, 0.12));
    color: var(--servora-text);
    text-decoration: none;
    box-shadow: inset 3px 0 0 #ff3b30;
}

.servora-calendar-block:hover {
    color: var(--servora-text);
    filter: brightness(1.08);
}

.servora-calendar-block b,
.servora-calendar-day-event b {
    color: #ff8a82;
}

.servora-calendar-block span,
.servora-calendar-block small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-block span {
    font-weight: 800;
}

.servora-calendar-block small {
    color: var(--servora-text-soft);
}

.servora-calendar-day-view {
    display: grid;
    gap: 1rem;
}

.servora-calendar-day-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-calendar-day-title strong {
    font-size: 1.05rem;
}

.servora-calendar-day-title span {
    color: var(--servora-text-soft);
    font-weight: 700;
}

.servora-calendar-day-off-list {
    display: grid;
    gap: 0.55rem;
}

.servora-calendar-day-off {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(245, 158, 11, 0.28);
    border-radius: 0.75rem;
    background: rgba(245, 158, 11, 0.08);
}

.servora-calendar-day-off strong,
.servora-calendar-day-off span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-day-off span {
    color: #fbbf24;
    font-weight: 800;
}

.servora-calendar-time-summary-list {
    display: grid;
    gap: 0.55rem;
}

.servora-calendar-time-summary {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(59, 130, 246, 0.28);
    border-radius: 0.75rem;
    background: rgba(59, 130, 246, 0.08);
}

.servora-calendar-time-summary div {
    display: grid;
    gap: 0.12rem;
    min-width: 0;
}

.servora-calendar-time-summary strong,
.servora-calendar-time-summary span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-time-summary span {
    color: var(--servora-text-soft);
}

.servora-calendar-time-summary em {
    flex: 0 0 auto;
    color: #93c5fd;
    font-style: normal;
    font-weight: 900;
    white-space: nowrap;
}

.servora-calendar-day-timeline {
    display: grid;
    border-top: 1px solid var(--servora-border);
}

.servora-calendar-day-hour {
    display: grid;
    grid-template-columns: 5rem minmax(0, 1fr);
    min-height: 5.4rem;
    border-bottom: 1px solid var(--servora-border);
}

.servora-calendar-day-hour > time {
    padding-top: 0.9rem;
    color: var(--servora-text-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-align: center;
}

.servora-calendar-day-slot {
    display: grid;
    gap: 0.55rem;
    align-content: start;
    padding: 0.55rem 0 0.55rem 0.75rem;
    border-left: 1px solid var(--servora-border);
}

.servora-calendar-day-event {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 0.7rem 0.8rem;
    border-radius: 0.7rem;
    background: linear-gradient(135deg, rgba(255, 59, 48, 0.22), rgba(255, 59, 48, 0.08));
    color: var(--servora-text);
    text-decoration: none;
    box-shadow: inset 4px 0 0 #ff3b30;
}

.servora-calendar-day-event:hover {
    color: var(--servora-text);
    filter: brightness(1.08);
}

.servora-calendar-day-event div {
    display: grid;
    gap: 0.1rem;
    min-width: 0;
}

.servora-calendar-day-event strong,
.servora-calendar-day-event small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-calendar-day-event small {
    color: var(--servora-text-soft);
}

.servora-calendar-empty-slot {
    display: block;
    min-height: 2.4rem;
}

@media (max-width: 1199.98px) {
    .servora-calendar-app {
        grid-template-columns: 1fr;
    }

    .servora-calendar-shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .servora-calendar-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .servora-calendar-view-switch {
        width: 100%;
    }

    .servora-calendar-view-switch a {
        flex: 1 1 0;
    }

    .servora-calendar-filter {
        grid-template-columns: 1fr 1fr;
    }

    .servora-calendar-filter-actions {
        grid-column: 1 / -1;
    }
}

@media (max-width: 767.98px) {
    .servora-calendar-mini-stats {
        grid-template-columns: 1fr;
    }

    .servora-calendar-week-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-calendar-grid,
    .servora-calendar-month-grid {
        grid-template-columns: 1fr;
    }

    .servora-calendar-week-label {
        display: none;
    }

    .servora-calendar-day {
        min-height: 7.2rem;
    }

    .servora-calendar-filter {
        grid-template-columns: 1fr;
    }

    .servora-calendar-filter-actions {
        flex-direction: column;
    }

    .servora-calendar-day-hour {
        grid-template-columns: 4rem minmax(0, 1fr);
    }

    .servora-calendar-day-event {
        flex-direction: column;
    }
}

.servora-calendar-event-pill.is-time-off {
    background: rgba(245, 158, 11, 0.15);
    box-shadow: inset 3px 0 0 #f59e0b;
}

.servora-calendar-event-pill.is-time-off b {
    color: #fbbf24;
}

.servora-calendar-agenda-item.is-time-off {
    background: rgba(245, 158, 11, 0.08);
}

.servora-calendar-agenda-item.is-time-off time {
    background: rgba(245, 158, 11, 0.18);
    color: #fbbf24;
}

.servora-calendar-event-pill.is-time-entry {
    background: rgba(59, 130, 246, 0.14);
    box-shadow: inset 3px 0 0 #3b82f6;
}

.servora-calendar-event-pill.is-time-entry b,
.servora-calendar-block.is-time-entry b,
.servora-calendar-day-event.is-time-entry b {
    color: #93c5fd;
}

.servora-calendar-agenda-item.is-time-entry {
    background: rgba(59, 130, 246, 0.08);
}

.servora-calendar-agenda-item.is-time-entry time {
    background: rgba(59, 130, 246, 0.18);
    color: #93c5fd;
}

.servora-calendar-week-head em.is-time-entry {
    background: rgba(59, 130, 246, 0.13);
    color: #93c5fd;
}

.servora-calendar-block.is-time-entry {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(59, 130, 246, 0.08));
    box-shadow: inset 3px 0 0 #3b82f6;
}

.servora-calendar-day-event.is-time-entry {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.2), rgba(59, 130, 246, 0.08));
    box-shadow: inset 4px 0 0 #3b82f6;
}

.servora-worker-dashboard {
    display: grid;
    grid-template-columns: minmax(22rem, 0.48fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: stretch;
}

.servora-worker-clock-card {
    border-color: rgba(59, 130, 246, 0.24);
}

.servora-worker-clock-card.is-active {
    border-color: rgba(34, 197, 94, 0.36);
    box-shadow: 0 24px 70px rgba(34, 197, 94, 0.1);
}

.servora-worker-clock-card form {
    display: grid;
    gap: 1rem;
}

.servora-worker-clock-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: start;
}

.servora-worker-clock-head span {
    color: var(--servora-text-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-worker-clock-head h2 {
    margin: 0.2rem 0;
    font-size: 1.55rem;
}

.servora-worker-clock-head p {
    margin: 0;
    color: var(--servora-text-soft);
}

.servora-worker-clock-timer {
    min-width: 9.4rem;
    padding: 0.8rem 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.04);
    color: #ffffff;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 1.45rem;
    font-weight: 900;
    text-align: center;
}

.servora-worker-clock-card.is-active .servora-worker-clock-timer {
    background: rgba(34, 197, 94, 0.1);
    color: #4ade80;
}

.servora-worker-clock-button {
    min-height: 3rem;
    font-weight: 800;
}

.servora-worker-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.servora-worker-stat-value {
    font-size: 1.55rem;
}

.servora-worker-list {
    display: grid;
    gap: 0.7rem;
}

.servora-worker-row {
    display: grid;
    grid-template-columns: 4.2rem minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
    padding: 0.78rem 0.85rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.03);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-worker-row:hover {
    border-color: rgba(255, 59, 48, 0.38);
    color: var(--servora-text);
}

.servora-worker-row time {
    display: inline-flex;
    min-height: 2.25rem;
    align-items: center;
    justify-content: center;
    border-radius: 0.65rem;
    background: rgba(255, 59, 48, 0.12);
    color: #ff8a82;
    font-weight: 900;
}

.servora-worker-row span {
    display: grid;
    gap: 0.15rem;
    min-width: 0;
}

.servora-worker-row strong,
.servora-worker-row small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-worker-row small {
    color: var(--servora-text-soft);
}

.servora-worker-row em {
    font-style: normal;
}

@media (max-width: 1199.98px) {
    .servora-worker-dashboard {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .servora-worker-clock-head,
    .servora-worker-row {
        grid-template-columns: 1fr;
    }

    .servora-worker-clock-timer {
        width: 100%;
    }

    .servora-worker-stat-grid {
        grid-template-columns: 1fr;
    }
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

body.servora-body {
    min-height: 100vh;
    overflow-x: hidden;
    background:
        radial-gradient(circle at top right, rgba(224, 36, 36, 0.12), transparent 30%),
        linear-gradient(180deg, #07111c 0%, #09131f 100%);
    color: var(--servora-text);
}

body.servora-body.theme-light {
    --servora-bg: #f3f5f8;
    --servora-bg-soft: #ffffff;
    --servora-panel: #ffffff;
    --servora-panel-2: #edf1f6;
    --servora-border: rgba(15, 23, 42, 0.08);
    --servora-text: #0f172a;
    --servora-text-soft: #64748b;
    --servora-text-muted: #8090a6;
    background:
        radial-gradient(circle at top right, rgba(224, 36, 36, 0.08), transparent 32%),
        linear-gradient(180deg, #f4f6f9 0%, #eef2f7 100%);
}

a {
    color: inherit;
}

.servora-shell {
    background: transparent;
}

.servora-sidebar {
    background: rgba(10, 18, 29, 0.94);
    border-right: 1px solid var(--servora-border);
    min-height: 100vh;
    overflow: visible;
    z-index: 30;
    transition: width 0.22s ease;
}

.servora-sidebar .container-fluid {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: visible;
}

.servora-sidebar-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
}

.servora-brand {
    display: inline-flex;
    align-items: center;
    min-width: 0;
    gap: 0.85rem;
    text-decoration: none;
    color: var(--servora-text);
}

.servora-brand-mark {
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.9rem;
    background: linear-gradient(135deg, #ff3b30, #9c1111);
    font-size: 1.25rem;
    font-weight: 800;
    box-shadow: 0 12px 32px rgba(224, 36, 36, 0.3);
}

.servora-brand-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
    line-height: 1.1;
}

.servora-brand-text strong {
    letter-spacing: 0.2rem;
    font-size: 1rem;
}

.servora-brand-text small {
    color: var(--servora-text-soft);
    font-size: 0.7rem;
    letter-spacing: 0.08rem;
    text-transform: uppercase;
}

.auth-brand {
    display: inline-flex;
}

.servora-hp-field {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.servora-sidebar .nav-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: #d2d9e2;
    border-radius: 0.85rem;
    margin-bottom: 0.35rem;
    padding: 0.85rem 0.95rem;
}

.servora-sidebar-section {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin: 1.05rem 0 0.35rem;
    padding: 0 0.85rem;
    color: rgba(210, 217, 226, 0.56);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08rem;
    line-height: 1;
    text-transform: uppercase;
}

.servora-sidebar-section:first-child {
    margin-top: 0;
}

.servora-sidebar-section::after {
    content: "";
    height: 1px;
    flex: 1;
    background: rgba(148, 163, 184, 0.16);
}

.servora-sidebar .nav-link-icon {
    width: 1.5rem;
    min-width: 1.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.servora-sidebar .nav-link:hover,
.servora-sidebar .nav-link.active {
    background: linear-gradient(90deg, rgba(224, 36, 36, 0.18), rgba(224, 36, 36, 0.08));
    color: #fff;
}

.servora-sidebar-footer {
    margin-top: auto;
    padding-top: 1rem;
}

.servora-sidebar-toggle {
    border-color: var(--servora-border);
    color: var(--servora-text);
    background: rgba(255, 255, 255, 0.04);
}

.servora-mobile-drawer-head {
    display: none;
}

.servora-mobile-topbar,
.servora-mobile-menu-backdrop {
    display: none;
}

.servora-logout-icon {
    display: none;
}

@media (min-width: 992px) {
    html.servora-sidebar-collapsed .servora-sidebar {
        width: 5.25rem;
    }

    html.servora-sidebar-collapsed .servora-page-wrapper {
        margin-left: 5.25rem !important;
        width: calc(100% - 5.25rem);
    }

    html.servora-sidebar-collapsed .servora-topbar .container-xl,
    html.servora-sidebar-collapsed .servora-content {
        width: 100%;
        max-width: none !important;
    }

    html.servora-sidebar-collapsed .servora-sidebar .container-fluid {
        padding-inline: 0.85rem;
        align-items: center;
    }

    html.servora-sidebar-collapsed .servora-sidebar-head {
        justify-content: center;
        flex-direction: column;
    }

    html.servora-sidebar-collapsed .servora-brand-text,
    html.servora-sidebar-collapsed .servora-sidebar .nav-link-title,
    html.servora-sidebar-collapsed .servora-sidebar-section,
    html.servora-sidebar-collapsed .servora-user-card > div:not(.avatar),
    html.servora-sidebar-collapsed .servora-logout-label {
        display: none;
    }

    html.servora-sidebar-collapsed .servora-brand {
        justify-content: center;
    }

    html.servora-sidebar-collapsed .servora-brand-mark {
        width: 2.75rem;
        height: 2.75rem;
    }

    html.servora-sidebar-collapsed .servora-sidebar .navbar-collapse,
    html.servora-sidebar-collapsed .servora-sidebar .navbar-nav,
    html.servora-sidebar-collapsed .servora-sidebar .nav-item,
    html.servora-sidebar-collapsed .servora-sidebar-footer,
    html.servora-sidebar-collapsed .servora-sidebar-footer form {
        width: 100%;
    }

    html.servora-sidebar-collapsed .servora-sidebar .nav-link {
        justify-content: center;
        padding-inline: 0;
        min-height: 3rem;
    }

    html.servora-sidebar-collapsed .servora-sidebar .nav-link::after {
        content: attr(data-sidebar-label);
        position: absolute;
        left: calc(100% + 0.65rem);
        top: 50%;
        transform: translateY(-50%);
        z-index: 40;
        opacity: 0;
        pointer-events: none;
        white-space: nowrap;
        padding: 0.45rem 0.65rem;
        border-radius: 0.55rem;
        background: #111c2a;
        border: 1px solid var(--servora-border);
        color: var(--servora-text);
        box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
        transition: opacity 0.14s ease;
    }

    html.servora-sidebar-collapsed .servora-sidebar .nav-link:hover::after {
        opacity: 1;
    }

    html.servora-sidebar-collapsed .servora-user-card {
        justify-content: center;
        padding: 0.75rem;
    }

    html.servora-sidebar-collapsed .servora-logout-icon {
        display: inline-flex;
    }

    html.servora-sidebar-collapsed .servora-logout-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        padding-inline: 0;
        min-height: 2.75rem;
    }
}

.servora-user-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem;
    margin-bottom: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-user-name,
.servora-topbar-name {
    font-weight: 700;
}

.servora-user-role,
.servora-topbar-subtitle,
.page-subtitle,
.servora-auth-lead {
    color: var(--servora-text-soft);
}

.servora-user-package {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
    margin-top: 0.35rem;
}

.servora-user-package-label {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.45rem;
    border-radius: 999px;
    background: rgba(224, 36, 36, 0.12);
    border: 1px solid rgba(224, 36, 36, 0.18);
    color: #ffb2b2;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
}

.servora-user-package strong {
    font-size: 0.82rem;
    color: var(--servora-text);
    font-weight: 700;
}

.servora-user-package-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.28rem 0.6rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
}

.servora-user-package-badge.is-trial {
    background: rgba(240, 186, 45, 0.14);
    border-color: rgba(240, 186, 45, 0.24);
    color: #ffd55d;
}

.servora-user-package-badge.is-basic {
    background: rgba(58, 124, 255, 0.16);
    border-color: rgba(58, 124, 255, 0.22);
    color: #9ac0ff;
}

.servora-user-package-badge.is-pro {
    background: rgba(73, 194, 107, 0.16);
    border-color: rgba(73, 194, 107, 0.22);
    color: #8cf0a8;
}

.servora-user-package-badge.is-ultimate {
    background: rgba(224, 36, 36, 0.16);
    border-color: rgba(224, 36, 36, 0.24);
    color: #ffb2b2;
}

.servora-user-package-badge.is-default {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.1);
    color: var(--servora-text-soft);
}

.servora-page-wrapper {
    margin-left: 0;
}

.servora-topbar {
    position: relative;
    z-index: 120;
    background: rgba(7, 17, 28, 0.72);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--servora-border);
}

body.servora-body.theme-light .servora-topbar {
    background: rgba(255, 255, 255, 0.86);
}

.servora-topbar .container-xl,
.servora-content {
    max-width: 1600px;
}

.servora-topbar .container-xl {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1rem;
}

.servora-topbar-left {
    min-width: max-content;
}

.servora-quick-actions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.servora-quick-btn {
    border-radius: 999px;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.04);
    color: var(--servora-text);
    padding-inline: 0.9rem;
}

.servora-topbar-menu-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.servora-quick-btn:hover {
    background: var(--servora-accent-soft);
    border-color: rgba(224, 36, 36, 0.32);
    color: var(--servora-text);
}

.servora-search .form-control {
    min-width: 20rem;
    background: rgba(255, 255, 255, 0.03);
    border-color: var(--servora-border);
    color: var(--servora-text);
}

.servora-search {
    position: relative;
    z-index: 130;
}

.servora-search .form-control::placeholder {
    color: #7f8da0;
}

.servora-search-panel {
    position: absolute;
    top: calc(100% + 0.55rem);
    left: 0;
    right: 0;
    z-index: 140;
    max-height: min(34rem, calc(100vh - 7rem));
    overflow-y: auto;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 0.85rem;
    background: rgba(9, 18, 30, 0.98);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.34);
    padding: 0.65rem;
}

body.servora-body.theme-light .servora-search-panel {
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.16);
}

.servora-search-panel-group + .servora-search-panel-group {
    margin-top: 0.55rem;
    padding-top: 0.55rem;
    border-top: 1px solid rgba(148, 163, 184, 0.14);
}

.servora-search-panel-title {
    padding: 0.35rem 0.55rem;
    color: var(--servora-text-soft);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08rem;
    text-transform: uppercase;
}

.servora-search-panel-row,
.servora-search-panel-all {
    display: grid;
    grid-template-columns: 6.5rem minmax(0, 1fr);
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 0.7rem;
    border-radius: 0.65rem;
    color: var(--servora-text);
    text-decoration: none;
}

.servora-search-panel-row:hover,
.servora-search-panel-all:hover {
    background: rgba(224, 36, 36, 0.12);
    color: var(--servora-text);
}

.servora-search-panel-type {
    color: #ff6b62;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.04rem;
    text-transform: uppercase;
}

.servora-search-panel-row strong,
.servora-search-panel-row small {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-search-panel-row small {
    color: var(--servora-text-soft);
}

.servora-search-panel-all {
    display: block;
    margin-top: 0.55rem;
    text-align: center;
    font-weight: 700;
    color: #ff6b62;
    border-top: 1px solid rgba(148, 163, 184, 0.14);
}

.servora-search-panel-state {
    padding: 0.85rem;
    color: var(--servora-text-soft);
}

.servora-topbar-user {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    max-width: 15rem;
}

.servora-topbar-logo-avatar {
    width: 2rem !important;
    height: 2rem !important;
    min-width: 2rem;
    min-height: 2rem;
    border-radius: 0.65rem !important;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border: 1px solid var(--servora-border);
    flex: 0 0 auto;
}

.servora-topbar-user > div:last-child {
    min-width: 0;
}

.servora-topbar-name,
.servora-topbar-subtitle {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-theme-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    border-radius: 999px;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.04);
    color: var(--servora-text);
    white-space: nowrap;
}

.servora-theme-toggle:hover {
    background: rgba(255, 255, 255, 0.08);
    color: var(--servora-text);
}

.servora-content {
    padding: 1.75rem;
    min-width: 0;
    width: 100%;
}

.servora-search-page-form {
    max-width: 52rem;
}

.servora-search-page-form .form-control {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--servora-border);
    color: var(--servora-text);
}

.servora-search-results-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.servora-search-result-section {
    border: 1px solid var(--servora-border);
    border-radius: 0.5rem;
    background: rgba(17, 28, 42, 0.72);
    overflow: hidden;
}

body.servora-body.theme-light .servora-search-result-section {
    background: rgba(255, 255, 255, 0.78);
}

.servora-search-result-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--servora-border);
}

.servora-search-result-head h2 {
    margin: 0;
    font-size: 1rem;
}

.servora-search-result-head span {
    color: var(--servora-text-soft);
    font-size: 0.8rem;
}

.servora-search-result-list {
    display: grid;
}

.servora-search-result-row {
    display: grid;
    grid-template-columns: 7rem minmax(0, 1fr);
    gap: 0.85rem;
    padding: 0.85rem 1rem;
    color: var(--servora-text);
    text-decoration: none;
}

.servora-search-result-row + .servora-search-result-row {
    border-top: 1px solid rgba(148, 163, 184, 0.12);
}

.servora-search-result-row:hover {
    background: rgba(224, 36, 36, 0.1);
    color: var(--servora-text);
}

.servora-search-result-type {
    color: #ff6b62;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.04rem;
    text-transform: uppercase;
}

.servora-search-result-row strong,
.servora-search-result-row small {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-search-result-row small {
    color: var(--servora-text-soft);
}

.servora-card {
    background: rgba(17, 28, 42, 0.92);
    border: 1px solid var(--servora-border);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.18);
}

body.portal-page .servora-auth-shell {
    min-height: 100vh;
    width: 100%;
}

.servora-portal-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 18.5rem minmax(0, 1fr);
    background:
        radial-gradient(circle at 88% 8%, rgba(224, 36, 36, 0.16), transparent 28%),
        linear-gradient(180deg, #07111c 0%, #0a1421 100%);
}

.servora-portal-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: 1.35rem;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(8, 16, 28, 0.96);
}

.servora-portal-brand {
    padding-bottom: 0.5rem;
}

.servora-portal-user {
    display: grid;
    grid-template-columns: 3rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
    padding: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.04);
}

.servora-portal-avatar {
    width: 3rem;
    height: 3rem;
    display: inline-grid;
    place-items: center;
    border-radius: 0.9rem;
    background: rgba(224, 36, 36, 0.18);
    color: #fff;
    font-weight: 850;
    font-size: 1.15rem;
}

.servora-portal-user strong,
.servora-portal-user small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-portal-user strong {
    color: var(--servora-text);
    font-weight: 850;
}

.servora-portal-user small {
    color: var(--servora-text-soft);
}

.servora-portal-nav {
    display: grid;
    gap: 0.45rem;
}

.servora-portal-nav a,
.servora-portal-logout {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 3.05rem;
    padding: 0.78rem 0.9rem;
    border: 1px solid transparent;
    border-radius: 0.85rem;
    background: transparent;
    color: #d7deea;
    font-weight: 750;
    text-decoration: none;
    transition: 0.18s ease;
}

.servora-portal-nav a span,
.servora-portal-logout .icon {
    color: #f87171;
}

.servora-portal-nav a:hover,
.servora-portal-nav a.active,
.servora-portal-logout:hover {
    border-color: rgba(224, 36, 36, 0.26);
    background: linear-gradient(90deg, rgba(224, 36, 36, 0.2), rgba(224, 36, 36, 0.08));
    color: #fff;
}

.servora-portal-logout {
    width: 100%;
    justify-content: flex-start;
}

.servora-portal-main {
    min-width: 0;
    padding: 1.5rem;
}

.servora-portal-hero {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding: clamp(1.35rem, 3vw, 2.2rem);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.25rem;
    background:
        linear-gradient(135deg, rgba(224, 36, 36, 0.95), rgba(112, 20, 20, 0.9)),
        #e02424;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
}

.servora-portal-kicker,
.servora-portal-hero-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.78rem;
    font-weight: 800;
    padding: 0.35rem 0.7rem;
}

.servora-portal-hero h1 {
    margin: 0.75rem 0 0.45rem;
    color: #fff;
    font-size: clamp(2rem, 4vw, 3.15rem);
    line-height: 1.05;
    letter-spacing: 0;
}

.servora-portal-hero p {
    margin: 0;
    max-width: 46rem;
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.05rem;
}

.servora-portal-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
    margin: 1rem 0;
}

.servora-portal-stats article,
.servora-portal-panel {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
    background: rgba(17, 28, 42, 0.92);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.servora-portal-stats article {
    display: grid;
    gap: 0.35rem;
    padding: 1rem;
}

.servora-portal-stats article > span,
.servora-portal-row-icon {
    width: 2.35rem;
    height: 2.35rem;
    display: inline-grid;
    place-items: center;
    border-radius: 0.75rem;
    background: rgba(224, 36, 36, 0.14);
    color: #f87171;
}

.servora-portal-stats small {
    color: var(--servora-text-soft);
    font-weight: 800;
    text-transform: uppercase;
    font-size: 0.74rem;
}

.servora-portal-stats strong {
    color: var(--servora-text);
    font-size: 1.65rem;
    line-height: 1.1;
}

.servora-portal-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(22rem, 0.65fr);
    gap: 1rem;
    align-items: start;
}

.servora-portal-wide {
    grid-row: span 2;
}

.servora-portal-panel {
    padding: 1.1rem;
}

.servora-portal-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.servora-portal-panel h2 {
    margin: 0;
    color: var(--servora-text);
    font-size: 1.35rem;
    letter-spacing: 0;
}

.servora-portal-panel p {
    margin: 0.25rem 0 0;
    color: var(--servora-text-soft);
}

.servora-portal-list {
    display: grid;
    gap: 0.65rem;
}

.servora-portal-list-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.85rem;
    align-items: center;
    min-height: 4.35rem;
    padding: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-portal-list-row:hover {
    border-color: rgba(224, 36, 36, 0.32);
    background: rgba(224, 36, 36, 0.08);
    color: var(--servora-text);
}

.servora-portal-list-row strong,
.servora-portal-list-row small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-portal-list-row small {
    color: var(--servora-text-soft);
}

.servora-portal-profile {
    display: grid;
    gap: 0.65rem;
}

.servora-portal-profile > div,
.servora-portal-appointment {
    padding: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-portal-profile span,
.servora-portal-appointment span,
.servora-portal-appointment small {
    display: block;
    color: var(--servora-text-soft);
}

.servora-portal-profile strong,
.servora-portal-appointment strong {
    color: var(--servora-text);
    overflow-wrap: anywhere;
}

.servora-portal-quick {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.servora-portal-quick a {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-height: 3.5rem;
    padding: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    font-weight: 800;
    text-decoration: none;
}

.servora-portal-quick a:hover {
    border-color: rgba(224, 36, 36, 0.32);
    background: rgba(224, 36, 36, 0.08);
}

.servora-portal-quick svg {
    color: #f87171;
}

.servora-portal-empty {
    display: grid;
    place-items: center;
    gap: 0.6rem;
    min-height: 8rem;
    padding: 1rem;
    border: 1px dashed rgba(148, 163, 184, 0.28);
    border-radius: 0.9rem;
    color: var(--servora-text-soft);
    text-align: center;
}

.servora-portal-empty svg {
    color: #f87171;
}

.servora-vehicle-hero {
    margin-bottom: 1rem;
}

.servora-vehicle-page-grid {
    display: grid;
    grid-template-columns: minmax(20rem, 0.52fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

[data-portal-live-scope] {
    transition: opacity 0.16s ease;
}

[data-portal-live-scope][aria-busy="true"] {
    opacity: 0.62;
    pointer-events: none;
}

.servora-vehicle-selector-list {
    display: grid;
    gap: 0.75rem;
}

.servora-vehicle-selector-card {
    display: grid;
    grid-template-columns: 3.2rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
    min-height: 5.5rem;
    padding: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-vehicle-selector-card:hover,
.servora-vehicle-selector-card.is-active {
    border-color: rgba(224, 36, 36, 0.42);
    background: linear-gradient(135deg, rgba(224, 36, 36, 0.16), rgba(255, 255, 255, 0.04));
    color: var(--servora-text);
}

.servora-vehicle-selector-thumb {
    width: 3.2rem;
    height: 3.2rem;
    display: inline-grid;
    place-items: center;
    border-radius: 0.85rem;
    background: rgba(224, 36, 36, 0.14);
    color: #f87171;
}

.servora-vehicle-selector-card strong,
.servora-vehicle-selector-card small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-vehicle-selector-card strong {
    font-weight: 850;
}

.servora-vehicle-selector-card small {
    color: var(--servora-text-soft);
}

.servora-vehicle-detail-card {
    padding: 1.15rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.05rem;
    background: rgba(17, 28, 42, 0.92);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.servora-vehicle-detail-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.servora-vehicle-detail-head h2 {
    margin: 0.45rem 0 0.35rem;
    color: var(--servora-text);
    font-size: clamp(1.9rem, 3vw, 3rem);
    line-height: 1.05;
    letter-spacing: 0;
}

.servora-vehicle-detail-head p {
    margin: 0;
    color: var(--servora-text-soft);
    font-weight: 650;
}

.servora-vehicle-summary-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1rem;
}

.servora-vehicle-summary-chips span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.35rem;
    padding: 0.45rem 0.75rem;
    border: 1px solid rgba(224, 36, 36, 0.25);
    border-radius: 999px;
    background: rgba(224, 36, 36, 0.09);
    color: var(--servora-text-soft);
    font-weight: 750;
}

.servora-vehicle-summary-chips svg {
    color: #f87171;
}

.servora-vehicle-summary-chips strong {
    color: var(--servora-text);
}

.servora-vehicle-cockpit {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(17rem, 0.75fr);
    gap: 1rem;
    align-items: stretch;
}

.servora-vehicle-phantom-card {
    min-height: 25rem;
    display: grid;
    place-items: center;
    padding: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)),
        radial-gradient(circle at 50% 72%, rgba(224, 36, 36, 0.18), transparent 38%);
}

.servora-vehicle-phantom-svg {
    width: min(100%, 43rem);
    max-height: 22rem;
}

.servora-vehicle-side-metrics {
    display: grid;
    gap: 0.75rem;
}

.servora-vehicle-side-metrics article,
.servora-vehicle-data-grid > div {
    padding: 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-vehicle-side-metrics span,
.servora-vehicle-data-grid span {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--servora-text-soft);
    font-size: 0.78rem;
    font-weight: 850;
    text-transform: uppercase;
}

.servora-vehicle-side-metrics strong,
.servora-vehicle-data-grid strong {
    color: var(--servora-text);
    font-size: 1.25rem;
    overflow-wrap: anywhere;
}

.servora-vehicle-side-metrics small {
    display: block;
    color: var(--servora-text-soft);
}

.servora-vehicle-data-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.servora-vehicle-quotes {
    margin-top: 1.1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.servora-garage-shell {
    min-height: 100vh;
    background:
        radial-gradient(circle at 82% 16%, rgba(224, 36, 36, 0.14), transparent 32%),
        linear-gradient(180deg, #07111c 0%, #0a111d 100%);
    color: var(--servora-text);
}

.servora-garage-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    min-height: 4.6rem;
    padding: 0.8rem clamp(1rem, 3vw, 2rem);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(7, 17, 28, 0.88);
    backdrop-filter: blur(18px);
}

.servora-garage-topnav {
    display: flex;
    justify-content: center;
    gap: 0.35rem;
    align-items: center;
}

.servora-garage-topnav > a,
.servora-garage-menu > button,
.servora-garage-logout,
.servora-garage-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.55rem;
    padding: 0.55rem 0.8rem;
    border: 1px solid transparent;
    border-radius: 0.65rem;
    background: transparent;
    color: var(--servora-text-soft);
    font-size: 0.92rem;
    font-weight: 800;
    text-decoration: none;
}

.servora-garage-topnav > a:hover,
.servora-garage-topnav > a.active,
.servora-garage-menu:hover > button,
.servora-garage-menu:focus-within > button,
.servora-garage-logout:hover,
.servora-garage-icon-btn:hover {
    border-color: rgba(224, 36, 36, 0.28);
    background: rgba(224, 36, 36, 0.11);
    color: var(--servora-text);
}

.servora-garage-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.35rem;
}

.servora-garage-actions form {
    margin: 0;
}

.servora-garage-icon-btn,
.servora-garage-logout {
    width: 2.55rem;
    padding-inline: 0;
}

.servora-garage-menu {
    position: relative;
    padding-block: 0.2rem;
}

.servora-garage-dropdown {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: min(24rem, calc(100vw - 2rem));
    display: grid;
    gap: 0.45rem;
    padding: 0.65rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.85rem;
    background: rgba(13, 24, 38, 0.98);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
    opacity: 0;
    pointer-events: none;
    translate: 0 -0.3rem;
    transition: 0.16s ease;
    z-index: 30;
}

.servora-garage-menu:hover .servora-garage-dropdown,
.servora-garage-menu:focus-within .servora-garage-dropdown {
    opacity: 1;
    pointer-events: auto;
    translate: 0 0;
}

.servora-garage-dropdown a,
.servora-garage-dropdown span {
    display: grid;
    gap: 0.15rem;
    padding: 0.75rem;
    border-radius: 0.7rem;
    color: var(--servora-text);
    text-decoration: none;
}

.servora-garage-dropdown a:hover,
.servora-garage-dropdown a.is-active {
    background: rgba(224, 36, 36, 0.14);
}

.servora-garage-dropdown small {
    color: var(--servora-text-soft);
}

.servora-garage-main {
    width: calc(100vw - 1.25rem);
    max-width: 1680px;
    margin: 0 auto;
    padding: clamp(1rem, 2.5vw, 2rem) 0 3rem;
}

.servora-garage-live-detail {
    width: 100%;
}

.servora-garage-hero {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(23rem, 0.72fr) minmax(0, 1fr);
    min-height: 26rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.1rem;
    background: rgba(17, 28, 42, 0.88);
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.26);
}

.servora-garage-details {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(1.4rem, 4vw, 3rem);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(15, 23, 42, 0.16));
}

.servora-garage-eyebrow {
    color: #f87171;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-garage-details h1 {
    margin: 0.85rem 0 0.25rem;
    color: var(--servora-text);
    font-size: clamp(2rem, 3.5vw, 3.55rem);
    line-height: 1;
    letter-spacing: 0;
}

.servora-garage-details p {
    margin: 0 0 1.25rem;
    color: var(--servora-text-soft);
    font-size: 1rem;
}

.servora-garage-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
    padding-top: 1.1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.servora-garage-facts > div {
    display: grid;
    gap: 1rem;
    padding: 0.7rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.7rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text-soft);
    font-size: 0.86rem;
}

.servora-garage-facts strong {
    color: var(--servora-text);
    overflow-wrap: anywhere;
}

.servora-garage-visual {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    min-width: 0;
    padding: clamp(1.2rem, 3vw, 2rem);
    background:
        radial-gradient(circle at 50% 55%, rgba(255, 255, 255, 0.08), transparent 40%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.04), rgba(224, 36, 36, 0.04));
}

.servora-reminder-hero-strip {
    position: relative;
    z-index: 2;
    width: min(100%, 56rem);
    margin: 0 auto 1rem;
    padding: 0.9rem;
    border: 1px solid rgba(248, 113, 113, 0.2);
    border-radius: 0.9rem;
    background: linear-gradient(135deg, rgba(15, 23, 42, 0.9), rgba(55, 20, 32, 0.72));
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
}

.servora-reminder-hero-strip-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
}

.servora-reminder-hero-strip-head > div {
    display: grid;
    gap: 0.2rem;
}

.servora-reminder-hero-strip-head strong {
    color: var(--servora-text);
    font-size: 1.05rem;
}

.servora-reminder-hero-strip .servora-history-action {
    min-height: 2.35rem;
    padding: 0.45rem 0.75rem;
}

.servora-reminder-hero-items {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    margin-top: 0.75rem;
}

.servora-reminder-hero-items > span {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
    padding: 0.65rem 0.75rem;
    border: 1px solid rgba(148, 163, 184, 0.14);
    border-radius: 0.75rem;
    background: rgba(2, 6, 23, 0.28);
}

.servora-reminder-hero-items strong {
    color: var(--servora-text);
    font-size: 0.86rem;
    line-height: 1.2;
}

.servora-reminder-hero-items small {
    color: #fecaca;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.servora-garage-image-frame {
    display: grid;
    place-items: center;
    height: clamp(15rem, 27vw, 23rem);
    min-height: 0;
}

.servora-garage-image-frame img {
    width: 100%;
    height: 100%;
    max-height: none;
    object-fit: contain;
    border-radius: 0.85rem;
}

.servora-garage-image-frame .servora-vehicle-phantom-svg {
    width: min(100%, 50rem);
    max-height: 27rem;
}

.servora-garage-upload {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.servora-garage-upload label,
.servora-garage-delete-image {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 2.55rem;
    padding: 0.55rem 0.85rem;
    border: 1px solid rgba(224, 36, 36, 0.34);
    border-radius: 0.65rem;
    background: rgba(224, 36, 36, 0.12);
    color: var(--servora-text);
    font-weight: 850;
    cursor: pointer;
}

.servora-garage-delete-image {
    border-color: rgba(248, 113, 113, 0.32);
    background: rgba(127, 29, 29, 0.2);
    color: #fecaca;
}

.servora-garage-delete-image:hover {
    background: rgba(127, 29, 29, 0.34);
    color: #fff;
}

.servora-garage-upload input {
    display: none;
}

.servora-garage-upload small,
.servora-garage-muted {
    color: var(--servora-text-soft);
}

.servora-garage-accordions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.servora-garage-accordions details {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.9rem;
    background: rgba(17, 28, 42, 0.86);
    overflow: hidden;
}

.servora-garage-accordions details[open] {
    border-color: rgba(248, 113, 113, 0.22);
    background: rgba(12, 23, 36, 0.94);
}

.servora-garage-accordions summary {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.1rem;
    color: var(--servora-text);
    font-weight: 900;
    cursor: pointer;
    list-style: none;
}

.servora-garage-accordions summary::-webkit-details-marker {
    display: none;
}

.servora-garage-accordions summary span {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.servora-garage-accordions details > p {
    margin: 0;
    padding: 0 1.1rem 1rem;
}

.servora-garage-list {
    display: grid;
    gap: 0.65rem;
    padding: 0 1.1rem 1rem;
}

.servora-garage-list a {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 0.8rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-garage-list a:hover {
    background: rgba(224, 36, 36, 0.1);
    color: var(--servora-text);
}

.servora-garage-list-card {
    display: grid;
    gap: 0.75rem;
    padding: 0.8rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-garage-list-card > span:first-child {
    min-width: 0;
}

.servora-garage-list-card > .badge {
    justify-self: start;
}

.servora-garage-card-links {
    display: grid;
    gap: 0.45rem;
}

.servora-garage-card-links a {
    display: block;
    padding: 0.55rem 0.7rem;
    border-radius: 0.5rem;
    background: rgba(34, 197, 94, 0.08);
    color: #86efac;
}

.servora-garage-list small {
    display: block;
    color: var(--servora-text-soft);
}

.servora-garage-bottom {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.servora-garage-bottom a,
.servora-garage-empty {
    display: flex;
    gap: 0.85rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.9rem;
    background: rgba(17, 28, 42, 0.82);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-garage-bottom a:hover {
    border-color: rgba(224, 36, 36, 0.34);
    background: rgba(224, 36, 36, 0.09);
}

.servora-garage-bottom svg,
.servora-garage-topnav svg,
.servora-garage-upload svg,
.servora-garage-accordions svg {
    color: #f87171;
}

.servora-topbar-notification-btn,
.servora-garage-icon-btn {
    position: relative;
}

.servora-notification-badge {
    position: absolute;
    top: -0.25rem;
    right: -0.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.15rem;
    height: 1.15rem;
    padding: 0 0.25rem;
    border: 2px solid #0b1220;
    border-radius: 999px;
    background: #ef4444;
    color: #fff;
    font-size: 0.62rem;
    font-weight: 900;
    line-height: 1;
}

.servora-notification-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.servora-notification-row:last-child {
    border-bottom: 0;
}

.servora-notification-row.is-unread {
    background: rgba(224, 36, 36, 0.08);
}

.servora-notification-row-head {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 0.35rem;
}

.servora-notification-row-head strong {
    color: var(--servora-text);
}

.servora-notification-row-head span,
.servora-notification-row p {
    color: var(--servora-text-soft);
}

.servora-notification-row p {
    margin: 0 0 0.75rem;
}

.servora-choice-stack {
    display: grid;
    gap: 0.75rem;
}

.servora-choice-stack label,
.servora-recipient-grid label {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 0.65rem;
    background: rgba(15, 23, 42, 0.42);
    cursor: pointer;
}

.servora-choice-stack span,
.servora-recipient-grid strong {
    display: block;
    color: var(--servora-text);
    font-weight: 800;
}

.servora-choice-stack small,
.servora-recipient-grid small {
    display: block;
    color: var(--servora-text-soft);
}

.servora-recipient-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 0.75rem;
    max-height: 21rem;
    overflow: auto;
    padding: 0.25rem;
    border: 1px solid rgba(148, 163, 184, 0.14);
    border-radius: 0.75rem;
    background: rgba(2, 6, 23, 0.22);
}

.servora-recipient-grid[hidden] {
    display: none;
}

[data-recipient-picker].is-disabled {
    opacity: 0.58;
}

.servora-recipient-picker-head,
.servora-recipient-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.servora-recipient-picker-head span {
    color: var(--servora-text-soft);
    font-size: 0.9rem;
    font-weight: 800;
}

.servora-recipient-toolbar .form-control {
    min-width: 0;
}

.servora-recipient-grid label {
    margin: 0;
}

.servora-recipient-grid label[hidden] {
    display: none;
}

.servora-garage-bottom strong,
.servora-garage-bottom small {
    display: block;
}

.servora-garage-bottom small {
    color: var(--servora-text-soft);
}

.servora-garage-empty {
    justify-content: center;
    min-height: 16rem;
}

.servora-quote-hero {
    margin-bottom: 1rem;
}

.servora-quote-hero-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.55rem;
}

.servora-quote-hero-badges span {
    display: inline-flex;
    gap: 0.3rem;
    align-items: center;
    width: fit-content;
    min-height: 2rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.86);
    font-weight: 800;
}

.servora-quote-hero-badges strong {
    color: #fff;
}

.servora-quote-page-grid {
    display: grid;
    grid-template-columns: minmax(21rem, 0.52fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.servora-quote-selector-list {
    display: grid;
    gap: 0.75rem;
}

.servora-quote-selector-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: start;
    min-height: 8rem;
    padding: 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    text-decoration: none;
}

.servora-quote-selector-card:hover,
.servora-quote-selector-card.is-active {
    border-color: rgba(224, 36, 36, 0.42);
    background: linear-gradient(135deg, rgba(224, 36, 36, 0.16), rgba(255, 255, 255, 0.04));
    color: var(--servora-text);
}

.servora-quote-selector-card strong,
.servora-quote-selector-card small,
.servora-quote-selector-card b {
    display: block;
}

.servora-quote-selector-card strong {
    margin-bottom: 0.4rem;
    font-size: 1.05rem;
    font-weight: 900;
}

.servora-quote-selector-card small {
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-quote-selector-card b {
    margin-top: 0.55rem;
    color: var(--servora-text);
}

.servora-quote-detail-card {
    padding: 1.15rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.05rem;
    background: rgba(17, 28, 42, 0.92);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.servora-quote-detail-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-quote-detail-top h2 {
    margin: 0.45rem 0 0.35rem;
    color: var(--servora-text);
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1.05;
    letter-spacing: 0;
}

.servora-quote-detail-top p {
    margin: 0;
    color: var(--servora-text-soft);
    font-weight: 650;
}

.servora-portal-title-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.75rem;
}

.servora-portal-title-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 1.85rem;
    padding: 0.25rem 0.55rem;
    border: 1px solid rgba(248, 113, 113, 0.28);
    border-radius: 999px;
    background: rgba(224, 36, 36, 0.12);
    color: #fecaca;
    font-size: 0.78rem;
    font-weight: 850;
}

.servora-portal-title-tags.is-compact {
    gap: 0.35rem;
    margin: 0.45rem 0 0.2rem;
}

.servora-portal-title-tags.is-compact span {
    min-height: 1.45rem;
    padding: 0.12rem 0.45rem;
    font-size: 0.68rem;
}

.servora-history-launch .servora-garage-list-card {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
}

.servora-history-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.45rem;
    padding: 0.55rem 0.85rem;
    border: 1px solid rgba(248, 113, 113, 0.32);
    border-radius: 0.75rem;
    background: rgba(224, 36, 36, 0.12);
    color: #fee2e2;
    font-weight: 850;
    text-decoration: none;
}

.servora-history-action:hover {
    border-color: rgba(248, 113, 113, 0.52);
    background: rgba(224, 36, 36, 0.2);
    color: #ffffff;
}

.servora-service-history-page .servora-garage-main {
    max-width: 1320px;
}

.servora-service-history-hero {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-end;
    padding: 1.6rem;
    border: 1px solid rgba(248, 113, 113, 0.22);
    border-radius: 1.1rem;
    background: linear-gradient(135deg, rgba(224, 36, 36, 0.95), rgba(56, 20, 31, 0.96));
}

.servora-service-history-hero h1 {
    margin: 0.45rem 0 0.35rem;
    color: #ffffff;
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: 1.05;
    letter-spacing: 0;
}

.servora-service-history-hero p {
    margin: 0;
    color: rgba(255, 255, 255, 0.76);
    font-weight: 700;
}

.servora-service-history-actions,
.servora-history-controls {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.servora-service-history-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.servora-service-history-summary article,
.servora-service-history-row {
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.95rem;
    background: rgba(17, 28, 42, 0.88);
}

.servora-service-history-summary article {
    padding: 1rem;
}

.servora-service-history-summary span,
.servora-history-date span,
.servora-history-main p {
    color: var(--servora-text-soft);
}

.servora-service-history-summary strong {
    display: block;
    margin-top: 0.35rem;
    color: var(--servora-text);
    font-size: 1.25rem;
}

.servora-service-history-timeline {
    display: grid;
    gap: 0.85rem;
    margin-top: 1rem;
}

.servora-service-history-row {
    display: grid;
    grid-template-columns: 170px minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
}

.servora-history-date strong,
.servora-history-date span,
.servora-history-main strong,
.servora-history-main p {
    display: block;
}

.servora-history-date strong,
.servora-history-main strong {
    color: var(--servora-text);
}

.servora-history-main p {
    margin: 0.45rem 0 0.35rem;
}

.servora-history-note {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.85rem;
    background: rgba(15, 23, 42, 0.36);
}

.servora-history-note span {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--servora-text-soft);
    font-weight: 850;
}

.servora-history-note p {
    margin: 0;
    color: var(--servora-text);
}

.servora-reminder-overview {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 1rem;
    background: rgba(17, 28, 42, 0.88);
}

.servora-reminder-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.servora-reminder-summary-grid article {
    padding: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-reminder-summary-grid span,
.servora-reminder-summary-grid small,
.servora-reminder-pill-list small {
    color: var(--servora-text-soft);
}

.servora-reminder-summary-grid strong {
    display: block;
    margin: 0.35rem 0;
    color: var(--servora-text);
    font-size: 1.2rem;
}

.servora-reminder-pill-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 1rem;
}

.servora-reminder-pill-list > span {
    display: inline-flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 150px;
    padding: 0.65rem 0.8rem;
    border: 1px solid rgba(248, 113, 113, 0.24);
    border-radius: 0.8rem;
    background: rgba(224, 36, 36, 0.1);
}

.servora-reminder-pill-list strong {
    color: #fee2e2;
}

.servora-reminder-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.servora-reminder-card {
    padding: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.9rem;
    background: rgba(15, 23, 42, 0.34);
}

.servora-reminder-card-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1rem;
}

.servora-reminder-card .form-check-label {
    color: var(--servora-text);
    font-weight: 850;
}

.servora-reminder-workorder-rule {
    display: grid;
    gap: 0.35rem;
    padding: 0.9rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.75rem;
    background: rgba(2, 6, 23, 0.22);
}

.servora-reminder-workorder-rule span,
.servora-reminder-workorder-rule small {
    color: var(--servora-muted);
}

.servora-reminder-workorder-rule strong {
    color: #fecaca;
    font-size: 1.05rem;
}

.servora-reminder-compact-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(59, 130, 246, 0.24);
    border-radius: 0.8rem;
    background: rgba(30, 64, 175, 0.16);
}

.servora-reminder-compact-head span,
.servora-reminder-compact-row span,
.servora-reminder-compact-row small {
    color: var(--servora-muted);
}

.servora-reminder-compact-head strong {
    display: block;
    color: var(--servora-text);
    font-size: 0.92rem;
}

.servora-reminder-compact-head .form-control {
    width: min(18rem, 100%);
}

.servora-reminder-compact-list {
    display: grid;
    gap: 0.55rem;
}

.servora-reminder-compact-row {
    display: grid;
    grid-template-columns: minmax(12rem, 1fr) minmax(14rem, 1fr);
    gap: 1rem;
    align-items: center;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.75rem;
    background: rgba(15, 23, 42, 0.34);
}

.servora-reminder-compact-row strong {
    display: block;
    color: #f8fafc;
}

.servora-reminder-compact-row [data-expected-reminder-label] {
    color: #fecaca;
    font-size: 1.02rem;
}

.servora-reminder-hub {
    overflow: hidden;
}

.servora-reminder-tile-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.servora-reminder-tile {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    min-height: 10.5rem;
    padding: 1.15rem;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 0.9rem;
    background: linear-gradient(145deg, rgba(15, 23, 42, 0.84), rgba(30, 41, 59, 0.55));
    color: var(--servora-text);
    text-align: left;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.servora-reminder-tile:hover,
.servora-reminder-tile:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(248, 113, 113, 0.48);
    box-shadow: 0 1.15rem 2.4rem rgba(0, 0, 0, 0.22);
    outline: none;
}

.servora-reminder-tile.is-active {
    border-color: rgba(248, 113, 113, 0.48);
    background: linear-gradient(145deg, rgba(127, 29, 29, 0.34), rgba(15, 23, 42, 0.86));
}

.servora-reminder-tile-icon {
    display: grid;
    place-items: center;
    width: 4.4rem;
    height: 4.4rem;
    border: 1px solid rgba(248, 113, 113, 0.24);
    border-radius: 1rem;
    background: rgba(224, 36, 36, 0.12);
    color: #fca5a5;
}

.servora-reminder-tile.is-active .servora-reminder-tile-icon {
    background: rgba(224, 36, 36, 0.22);
    color: #fecaca;
}

.servora-reminder-tile-body {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 0.35rem;
    padding-right: 4.8rem;
}

.servora-reminder-tile-body strong {
    color: #f8fafc;
    font-size: 1.05rem;
    line-height: 1.2;
}

.servora-reminder-tile-body small {
    color: var(--servora-muted);
    line-height: 1.35;
}

.servora-reminder-tile-body em {
    margin-top: 0.4rem;
    color: #fecaca;
    font-style: normal;
    font-weight: 800;
}

.servora-reminder-tile-state {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.28rem 0.55rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.12);
    color: var(--servora-muted);
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.servora-reminder-tile.is-active .servora-reminder-tile-state {
    background: rgba(34, 197, 94, 0.14);
    color: #86efac;
}

.servora-reminder-modal-toggle,
.servora-reminder-notify-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.8rem;
    background: rgba(15, 23, 42, 0.36);
}

.servora-reminder-modal-toggle {
    justify-content: space-between;
    color: var(--servora-text);
    font-weight: 850;
}

.servora-reminder-modal-toggle input {
    width: 1.2rem;
    height: 1.2rem;
    accent-color: #ef4444;
}

@media (max-width: 900px) {
    .servora-service-history-hero,
    .servora-service-history-row {
        grid-template-columns: 1fr;
    }

    .servora-service-history-hero {
        align-items: flex-start;
        flex-direction: column;
    }

    .servora-service-history-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-reminder-summary-grid,
    .servora-reminder-tile-grid,
    .servora-reminder-compact-row,
    .servora-reminder-grid {
        grid-template-columns: 1fr;
    }

    .servora-reminder-compact-head {
        align-items: stretch;
        flex-direction: column;
    }

    .servora-reminder-compact-head .form-control {
        width: 100%;
    }
}

@media (max-width: 620px) {
    .servora-service-history-summary {
        grid-template-columns: 1fr;
    }

    .servora-history-launch .servora-garage-list-card {
        grid-template-columns: 1fr;
    }
}

@media print {
    .servora-print-hidden,
    .servora-service-history-modal {
        display: none !important;
    }

    .servora-body.portal-page,
    .servora-garage-shell,
    .servora-garage-main {
        background: #ffffff !important;
        color: #111827 !important;
    }

    .servora-service-history-hero,
    .servora-service-history-summary article,
    .servora-service-history-row {
        background: #ffffff !important;
        border-color: #d1d5db !important;
        color: #111827 !important;
        break-inside: avoid;
    }

    .servora-service-history-hero h1,
    .servora-service-history-summary strong,
    .servora-history-date strong,
    .servora-history-main strong,
    .servora-history-main p,
    .servora-service-history-hero p {
        color: #111827 !important;
    }
}

.servora-quote-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.55rem;
}

.servora-quote-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 1rem 0;
}

.servora-quote-metric-grid article,
.servora-quote-info-grid > div {
    padding: 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-quote-metric-grid span,
.servora-quote-info-grid span {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--servora-text-soft);
    font-size: 0.78rem;
    font-weight: 850;
    text-transform: uppercase;
}

.servora-quote-metric-grid strong,
.servora-quote-info-grid strong {
    color: var(--servora-text);
    font-size: 1.18rem;
    overflow-wrap: anywhere;
}

.servora-quote-status-card,
.servora-quote-items-card {
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.servora-quote-status-card .servora-portal-panel-head > span {
    color: var(--servora-text-soft);
    font-weight: 750;
}

.servora-quote-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-quote-items-card {
    margin-top: 1.1rem;
}

.servora-quote-items-table {
    overflow-x: auto;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0.95rem;
}

.servora-quote-items-head,
.servora-quote-item-line {
    display: grid;
    grid-template-columns: 7rem minmax(16rem, 1fr) 7rem 8rem 8rem;
    gap: 0.75rem;
    align-items: center;
    min-width: 48rem;
    padding: 0.85rem 1rem;
}

.servora-quote-items-head {
    color: var(--servora-text-soft);
    font-size: 0.78rem;
    font-weight: 850;
    text-transform: uppercase;
    background: rgba(255, 255, 255, 0.045);
}

.servora-quote-item-line {
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    color: var(--servora-text-soft);
}

.servora-quote-item-line strong {
    color: var(--servora-text);
    font-weight: 800;
}

@media (max-width: 1180px) {
    .servora-portal-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-portal-grid {
        grid-template-columns: 1fr;
    }

    .servora-portal-wide {
        grid-row: auto;
    }

    .servora-vehicle-page-grid,
    .servora-vehicle-cockpit,
    .servora-quote-page-grid {
        grid-template-columns: 1fr;
    }

    .servora-vehicle-data-grid,
    .servora-quote-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-garage-hero {
        grid-template-columns: 1fr;
    }

    .servora-garage-accordions,
    .servora-garage-facts {
        grid-template-columns: 1fr;
    }

    .servora-garage-bottom {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 860px) {
    .servora-portal-shell {
        grid-template-columns: 1fr;
    }

    .servora-portal-sidebar {
        position: relative;
        height: auto;
        padding: 1rem;
    }

    .servora-portal-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-portal-main {
        padding: 1rem;
    }

    .servora-portal-hero {
        flex-direction: column;
    }

    .servora-garage-topbar {
        grid-template-columns: 1fr;
        position: relative;
    }

    .servora-garage-topnav {
        justify-content: flex-start;
        overflow-x: auto;
        padding-bottom: 0.25rem;
    }

    .servora-garage-dropdown {
        left: 0;
        transform: none;
    }

    .servora-garage-details,
    .servora-garage-visual {
        padding: 1rem;
    }

    .servora-reminder-hero-strip-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .servora-reminder-hero-items {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .servora-portal-stats,
    .servora-portal-nav,
    .servora-portal-quick {
        grid-template-columns: 1fr;
    }

    .servora-portal-list-row {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .servora-portal-list-row .badge {
        grid-column: 2;
        width: fit-content;
    }

    .servora-vehicle-data-grid {
        grid-template-columns: 1fr;
    }

    .servora-quote-metric-grid,
    .servora-quote-info-grid {
        grid-template-columns: 1fr;
    }

    .servora-quote-detail-top {
        flex-direction: column;
    }

    .servora-vehicle-phantom-card {
        min-height: 16rem;
    }
}

.servora-table thead th {
    color: var(--servora-text-soft);
    font-size: 0.76rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.servora-table tbody td {
    vertical-align: middle;
}

.servora-empty-state {
    max-width: 28rem;
    margin: 0 auto;
}

.servora-type-switch {
    display: inline-flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.servora-type-option {
    position: relative;
    margin: 0;
    cursor: pointer;
}

.servora-type-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.servora-type-option span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 8.5rem;
    padding: 0.75rem 1rem;
    border-radius: 0.9rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.03);
    color: var(--servora-text);
    font-weight: 600;
    transition: 0.2s ease;
}

.servora-type-option input:checked + span {
    border-color: rgba(224, 36, 36, 0.5);
    background: linear-gradient(135deg, rgba(224, 36, 36, 0.22), rgba(224, 36, 36, 0.08));
    box-shadow: 0 8px 26px rgba(224, 36, 36, 0.18);
}

.servora-tabs.nav-tabs {
    border-bottom-color: var(--servora-border);
}

.servora-tabs .nav-link {
    color: var(--servora-text-soft);
    border: 0;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    padding-inline: 0;
    margin-right: 1.5rem;
    background: transparent;
}

.servora-tabs .nav-link.active,
.servora-tabs .nav-link:hover {
    color: var(--servora-text);
    border-bottom-color: var(--servora-accent);
    background: transparent;
}

.servora-modern-tabs.nav-tabs {
    align-items: center;
    background: rgba(15, 23, 42, 0.52);
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 14px;
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.18);
    display: inline-flex;
    flex-wrap: wrap;
    gap: 5px;
    max-width: 100%;
    padding: 5px;
}

.servora-modern-tabs .nav-item {
    margin: 0;
}

.servora-modern-tabs .nav-link {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 10px;
    color: #cbd5e1;
    display: inline-flex;
    font-size: 0.84rem;
    font-weight: 700;
    gap: 7px;
    line-height: 1;
    min-height: 36px;
    padding: 0 12px;
    transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
    white-space: nowrap;
}

.servora-modern-tabs .nav-link .icon {
    flex: 0 0 18px;
}

.servora-modern-tabs .nav-link:hover {
    background: rgba(255, 255, 255, 0.06);
    color: #f8fafc;
    transform: translateY(-1px);
}

.servora-modern-tabs .nav-link.active {
    background: rgba(239, 68, 68, 0.14);
    box-shadow: inset 0 0 0 1px rgba(239, 68, 68, 0.22);
    color: #fecaca;
}

.servora-modern-tabs .nav-link.active:hover {
    background: rgba(239, 68, 68, 0.2);
    color: #fff;
}

body.servora-body.theme-light .servora-modern-tabs.nav-tabs {
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(15, 23, 42, 0.1);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

body.servora-body.theme-light .servora-modern-tabs .nav-link {
    color: #64748b;
}

body.servora-body.theme-light .servora-modern-tabs .nav-link:hover {
    background: rgba(15, 23, 42, 0.05);
    color: #0f172a;
}

body.servora-body.theme-light .servora-modern-tabs .nav-link.active {
    background: rgba(224, 36, 36, 0.12);
    box-shadow: inset 0 0 0 1px rgba(224, 36, 36, 0.22);
    color: #b91c1c;
}

.servora-contact-panel {
    padding: 1.25rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.02);
}

.servora-contact-layout {
    display: grid;
    grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
}

.servora-contact-main {
    min-width: 0;
}

.servora-contact-profile-card {
    position: sticky;
    top: 1.25rem;
    overflow: hidden;
}

.servora-contact-summary-card {
    position: sticky;
    top: 1.25rem;
    overflow: hidden;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-contact-cover {
    height: 7.75rem;
    background:
        linear-gradient(135deg, rgba(224, 36, 36, 0.7), rgba(37, 99, 235, 0.48)),
        linear-gradient(180deg, rgba(255, 255, 255, 0.13), transparent);
}

.servora-contact-fact-list {
    display: grid;
    gap: 0.85rem;
    padding-top: 0.25rem;
}

.servora-contact-fact-list div {
    display: grid;
    grid-template-columns: 6.5rem minmax(0, 1fr);
    gap: 0.75rem;
    align-items: baseline;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--servora-border);
}

.servora-contact-fact-list div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.servora-contact-fact-list span {
    color: var(--servora-text-soft);
    font-weight: 650;
}

.servora-contact-fact-list strong {
    color: var(--servora-text);
    font-weight: 700;
    overflow-wrap: anywhere;
}

.servora-contact-list {
    display: grid;
    gap: 0.85rem;
}

.servora-contact-list-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.servora-view-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.025);
}

.servora-view-toggle-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.35rem;
    padding: 0.45rem 0.85rem;
    border-radius: 0.65rem;
    color: var(--servora-text-soft);
    font-weight: 750;
    text-decoration: none;
    white-space: nowrap;
}

.servora-view-toggle-button:hover,
.servora-view-toggle-button.is-active {
    color: var(--servora-text);
    background: rgba(224, 36, 36, 0.14);
}

.servora-contact-list-card {
    display: grid;
    grid-template-columns: minmax(280px, 1.35fr) minmax(420px, 1.65fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.025);
}

.servora-contact-list-main {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.servora-contact-list-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-contact-list-meta div {
    min-width: 0;
    padding: 0.7rem 0.8rem;
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.servora-contact-list-meta span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.74rem;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    margin-bottom: 0.15rem;
}

.servora-contact-list-meta strong {
    display: block;
    color: var(--servora-text);
    font-weight: 650;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-contact-list-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.servora-contact-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.servora-contact-grid-card {
    display: grid;
    gap: 0.9rem;
    align-content: start;
    min-width: 0;
    padding: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background:
        linear-gradient(135deg, rgba(224, 36, 36, 0.08), rgba(29, 78, 216, 0.04)),
        rgba(255, 255, 255, 0.025);
}

.servora-contact-grid-top {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.servora-contact-grid-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 999px;
    color: #ff5d57;
    font-weight: 850;
    background: rgba(224, 36, 36, 0.12);
    border: 1px solid rgba(224, 36, 36, 0.18);
}

.servora-contact-grid-card h3 {
    margin: 0;
    color: var(--servora-text);
    font-size: 1.05rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-contact-grid-code,
.servora-contact-grid-note {
    color: var(--servora-text-soft);
    font-size: 0.88rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-contact-grid-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.servora-contact-grid-details {
    display: grid;
    gap: 0.55rem;
}

.servora-contact-grid-details div,
.servora-contact-grid-footer > div:first-child {
    min-width: 0;
    padding: 0.72rem 0.8rem;
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.servora-contact-grid-details span,
.servora-contact-grid-footer span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    margin-bottom: 0.12rem;
}

.servora-contact-grid-details strong,
.servora-contact-grid-footer strong {
    display: block;
    color: var(--servora-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-contact-grid-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding-top: 0.15rem;
}

body.servora-body.theme-light .servora-contact-page-card {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.1);
    box-shadow: 0 18px 46px rgba(15, 23, 42, 0.08);
}

body.servora-body.theme-light .servora-contact-page-card .card-header,
body.servora-body.theme-light .servora-contact-page-card .card-footer {
    background: transparent;
}

body.servora-body.theme-light .servora-contact-list-card,
body.servora-body.theme-light .servora-contact-grid-card {
    background: #f8fafc;
    border-color: rgba(15, 23, 42, 0.1);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

body.servora-body.theme-light .servora-contact-list-meta div,
body.servora-body.theme-light .servora-contact-grid-details div,
body.servora-body.theme-light .servora-contact-grid-footer > div:first-child {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.1);
}

body.servora-body.theme-light .servora-view-toggle {
    background: #f1f5f9;
    border-color: rgba(15, 23, 42, 0.1);
}

body.servora-body.theme-light .servora-view-toggle-button {
    color: #64748b;
}

body.servora-body.theme-light .servora-view-toggle-button:hover,
body.servora-body.theme-light .servora-view-toggle-button.is-active {
    background: rgba(224, 36, 36, 0.12);
    color: #991b1b;
}

@media (max-width: 1399.98px) {
    .servora-contact-list-card {
        grid-template-columns: 1fr;
    }

    .servora-contact-list-actions {
        justify-content: flex-start;
    }

    .servora-contact-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .servora-contact-list-header,
    .servora-contact-grid-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .servora-view-toggle {
        width: 100%;
    }

    .servora-view-toggle-button {
        flex: 1;
    }

    .servora-contact-list-meta {
        grid-template-columns: 1fr;
    }

    .servora-contact-list-actions {
        flex-direction: column;
    }

    .servora-contact-grid {
        grid-template-columns: 1fr;
    }
}

.servora-contact-avatar {
    width: 5rem;
    height: 5rem;
    display: grid;
    place-items: center;
    margin: -2.5rem auto 0.9rem;
    border: 4px solid var(--servora-panel);
    border-radius: 50%;
    background: var(--servora-panel-2);
    color: var(--servora-text);
    font-size: 1.8rem;
    font-weight: 800;
    text-transform: uppercase;
}

.servora-employee-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.servora-employee-card {
    display: grid;
    gap: 0.9rem;
    padding: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background:
        linear-gradient(135deg, rgba(224, 36, 36, 0.08), rgba(29, 78, 216, 0.04)),
        rgba(255, 255, 255, 0.025);
}

.servora-employee-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.85rem;
    align-items: center;
}

.servora-employee-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 999px;
    color: #ff5d57;
    font-weight: 850;
    background: rgba(224, 36, 36, 0.12);
    border: 1px solid rgba(224, 36, 36, 0.18);
}

.servora-employee-head h2 {
    margin: 0;
    font-size: 1.05rem;
    color: var(--servora-text);
}

.servora-employee-head h2,
.servora-employee-head div div {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-employee-head div div {
    color: var(--servora-text-soft);
}

.servora-employee-facts {
    display: grid;
    gap: 0.55rem;
}

.servora-employee-facts div,
.servora-employee-permissions {
    min-width: 0;
    padding: 0.72rem 0.8rem;
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.servora-employee-facts span,
.servora-employee-permissions > span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    margin-bottom: 0.12rem;
}

.servora-employee-facts strong {
    display: block;
    color: var(--servora-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-employee-permissions div {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.servora-employee-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.servora-employee-form {
    display: grid;
    gap: 1rem;
}

.servora-employee-permission-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-employee-permission-card {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    padding: 0.85rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.025);
    cursor: pointer;
}

.servora-employee-permission-card input {
    margin-top: 0.18rem;
}

.servora-employee-permission-card strong {
    color: var(--servora-text);
}

@media (max-width: 1399.98px) {
    .servora-employee-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .servora-employee-grid,
    .servora-employee-permission-grid {
        grid-template-columns: 1fr;
    }

    .servora-employee-head {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .servora-employee-head .badge {
        grid-column: 1 / -1;
        justify-self: start;
    }

    .servora-employee-actions {
        flex-direction: column;
    }
}

.servora-contact-summary-name {
    margin: 0 0 0.45rem;
    font-size: 1.25rem;
    overflow-wrap: anywhere;
}

.servora-contact-badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.65rem;
    padding: 0.28rem 0.58rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 750;
    line-height: 1;
}

.servora-contact-badge.is-type {
    background: rgba(148, 163, 184, 0.13);
    color: #d9e2ef;
    border: 1px solid rgba(148, 163, 184, 0.18);
}

.servora-contact-badge.is-customer {
    background: rgba(73, 194, 107, 0.14);
    color: #91f2aa;
    border: 1px solid rgba(73, 194, 107, 0.24);
}

.servora-contact-badge.is-supplier {
    background: rgba(58, 124, 255, 0.15);
    color: #a8c7ff;
    border: 1px solid rgba(58, 124, 255, 0.25);
}

.servora-contact-summary-facts {
    display: grid;
    gap: 0.75rem;
    padding: 1rem 1.25rem 1.15rem;
}

.servora-contact-summary-facts div {
    display: grid;
    grid-template-columns: 7rem minmax(0, 1fr);
    gap: 0.7rem;
    align-items: baseline;
}

.servora-contact-summary-facts span {
    color: var(--servora-text-soft);
    font-weight: 650;
}

.servora-contact-summary-facts strong {
    min-width: 0;
    color: var(--servora-text);
    font-weight: 650;
    overflow-wrap: anywhere;
}

.servora-contact-summary-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
    padding: 1rem 1.25rem 1.25rem;
    border-top: 1px solid var(--servora-border);
}

.servora-contact-summary-actions .btn-outline-danger {
    grid-column: 1 / -1;
}

.servora-role-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.servora-role-option {
    cursor: pointer;
    margin: 0;
}

.servora-role-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.servora-role-option span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.95rem;
    min-width: 8rem;
    padding: 0.75rem 1rem;
    border-radius: 999px;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.03);
    color: var(--servora-text);
    font-weight: 750;
    transition: 0.2s ease;
}

.servora-role-option.is-customer input:checked + span {
    border-color: rgba(73, 194, 107, 0.34);
    background: rgba(73, 194, 107, 0.15);
    color: #9bf0b1;
}

.servora-role-option.is-supplier input:checked + span {
    border-color: rgba(58, 124, 255, 0.34);
    background: rgba(58, 124, 255, 0.16);
    color: #a8c7ff;
}

.servora-panel-title {
    color: var(--servora-text);
    font-weight: 800;
}

@media (max-width: 1199.98px) {
    .servora-contact-layout {
        grid-template-columns: 1fr;
    }

    .servora-contact-summary-card {
        position: static;
    }
}

@media (max-width: 575.98px) {
    .servora-contact-summary-facts div,
    .servora-contact-summary-actions {
        grid-template-columns: 1fr;
    }
}

.servora-module-picker {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.9rem;
}

.servora-module-option {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.9rem 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.03);
    cursor: pointer;
}

.servora-module-option input {
    margin-top: 0.2rem;
}

.servora-module-option span {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.servora-module-option span small {
    color: var(--servora-text-soft);
    line-height: 1.4;
}

.servora-extra-module-list {
    display: grid;
    gap: 0.85rem;
}

.servora-license-inner-tabs {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    max-width: 100%;
    padding: 0.35rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.9rem;
    background: rgba(15, 23, 42, 0.52);
}

.servora-license-inner-tabs .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border: 0;
    border-radius: 0.65rem;
    color: var(--servora-text-muted);
    font-weight: 750;
    padding: 0.58rem 0.85rem;
}

.servora-license-inner-tabs .nav-link span {
    display: inline-grid;
    place-items: center;
    min-width: 1.3rem;
    height: 1.3rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.14);
    color: var(--servora-text-soft);
    font-size: 0.72rem;
}

.servora-license-inner-tabs .nav-link.active,
.servora-license-inner-tabs .nav-link:hover {
    background: rgba(224, 36, 36, 0.16);
    color: var(--servora-text);
}

.servora-license-inner-tabs .nav-link.active span {
    background: rgba(224, 36, 36, 0.22);
    color: var(--servora-text);
}

.servora-extra-module-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-extra-module-main {
    display: grid;
    gap: 0.55rem;
    min-width: 0;
}

.servora-extra-module-check {
    display: grid;
    grid-template-columns: 1.1rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    margin: 0;
}

.servora-extra-module-check input {
    margin-top: 0.28rem;
}

.servora-extra-module-check span {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
}

.servora-extra-module-check strong {
    color: var(--servora-text);
    font-weight: 800;
}

.servora-extra-module-check small {
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-extra-module-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    padding-left: 1.95rem;
}

.servora-extra-module-controls {
    display: grid;
    grid-template-columns: minmax(150px, 1fr) minmax(150px, 1fr);
    gap: 0.75rem;
    align-items: end;
}

.servora-extra-module-controls .form-label {
    margin-bottom: 0.35rem;
    font-size: 0.78rem;
    color: var(--servora-text-soft);
}

@media (max-width: 1100px) {
    .servora-extra-module-row {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .servora-extra-module-controls {
        grid-template-columns: 1fr;
    }
}

.servora-license-create-strip .card-body {
    display: grid;
    grid-template-columns: minmax(240px, 0.9fr) minmax(0, 1.7fr);
    gap: 1.25rem;
    align-items: end;
}

.servora-license-create-copy {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
}

.servora-license-create-form {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(220px, 1.2fr) auto auto;
    gap: 0.9rem;
    align-items: end;
}

.servora-license-board {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
    align-items: stretch;
}

.servora-license-package-slot {
    min-width: 0;
}

.servora-license-package-card {
    display: grid;
    grid-template-rows: auto auto auto 1fr;
    gap: 1.05rem;
    height: 100%;
    padding: 1.35rem;
    border-radius: 1.05rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
        rgba(10, 17, 27, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.09);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
    position: relative;
    overflow: hidden;
}

.servora-license-package-card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, rgba(224, 36, 36, 0.9), rgba(224, 36, 36, 0.15));
    opacity: 0.85;
}

.servora-license-package-card.is-trial::before {
    background: linear-gradient(90deg, rgba(240, 186, 45, 0.95), rgba(240, 186, 45, 0.2));
}

.servora-license-package-card.is-basic::before {
    background: linear-gradient(90deg, rgba(76, 201, 240, 0.9), rgba(76, 201, 240, 0.15));
}

.servora-license-package-card.is-pro::before {
    background: linear-gradient(90deg, rgba(111, 207, 151, 0.9), rgba(111, 207, 151, 0.15));
}

.servora-license-package-card.is-ultimate::before {
    background: linear-gradient(90deg, rgba(180, 116, 255, 0.9), rgba(180, 116, 255, 0.15));
}

.servora-license-package-card.is-trial {
    border-color: rgba(240, 186, 45, 0.25);
    box-shadow:
        inset 0 0 0 1px rgba(240, 186, 45, 0.08),
        0 18px 36px rgba(0, 0, 0, 0.18);
}

.servora-license-package-head {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 1rem;
    padding-bottom: 0.95rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.servora-license-package-identity {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    min-width: 0;
}

.servora-license-icon {
    width: 2.55rem;
    height: 2.55rem;
    border-radius: 0.85rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: #ffb3b3;
    background: rgba(224, 36, 36, 0.12);
    border: 1px solid rgba(224, 36, 36, 0.2);
}

.servora-license-package-title-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 0.35rem;
}

.servora-license-package-title {
    margin: 0;
    font-size: 1.2rem;
}

.servora-license-slug {
    color: var(--servora-text-soft);
    font-size: 0.85rem;
    word-break: break-word;
}

.servora-license-description {
    min-height: 2.8rem;
    margin: 0;
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-license-package-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.servora-license-summary-box {
    padding: 0.9rem 1rem;
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    min-width: 0;
}

.servora-license-summary-box span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    margin-bottom: 0.25rem;
}

.servora-license-summary-box strong {
    display: block;
    font-size: 0.96rem;
    color: var(--servora-text);
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.servora-license-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    min-height: 4.2rem;
    padding: 0.85rem 0.95rem;
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.servora-license-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.48rem 0.8rem;
    border-radius: 999px;
    background: rgba(224, 36, 36, 0.1);
    border: 1px solid rgba(224, 36, 36, 0.18);
    color: #ffd9d9;
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1;
}

.servora-license-chip.is-empty {
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.08);
    color: var(--servora-text-soft);
    font-weight: 600;
}

.servora-price-pill-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.servora-price-pill {
    display: grid;
    gap: 0.15rem;
    padding: 0.7rem 0.75rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.servora-price-pill small {
    color: var(--servora-text-soft);
    text-transform: uppercase;
    letter-spacing: 0.04rem;
}

.servora-price-pill strong {
    color: var(--servora-text);
    font-size: 0.95rem;
}

.servora-price-pill.has-sale {
    border-color: rgba(73, 194, 107, 0.24);
    background: rgba(73, 194, 107, 0.08);
}

.servora-license-editor {
    display: grid;
    gap: 1.15rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    margin-top: 0.25rem;
}

.servora-license-editor-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.servora-license-payment-note {
    display: grid;
    gap: 0.25rem;
    padding: 0.95rem 1rem;
    border-radius: 0.85rem;
    color: #d8e8ff;
    background: rgba(29, 78, 216, 0.12);
    border: 1px solid rgba(96, 165, 250, 0.22);
}

.servora-license-payment-note span {
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-modal-content {
    background:
        linear-gradient(180deg, rgba(17, 28, 42, 0.98), rgba(10, 17, 27, 0.98)),
        #111c2a;
    color: var(--servora-text);
    border: 1px solid var(--servora-border);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.38);
}

.servora-modal-content > form {
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 5rem);
    min-height: 0;
}

.servora-modal-content .modal-header,
.servora-modal-content .modal-footer {
    border-color: var(--servora-border);
    flex: 0 0 auto;
}

.servora-modal-content .modal-body {
    overflow-y: auto;
    overflow-x: hidden;
    min-height: 0;
}

.servora-modal-content .modal-footer {
    position: sticky;
    bottom: 0;
    z-index: 2;
    background: rgba(10, 17, 27, 0.98);
    backdrop-filter: blur(10px);
}

.servora-modal-content .btn-close {
    filter: invert(1) grayscale(1);
    opacity: 0.75;
}

.servora-modal-section {
    height: 100%;
    padding: 1.05rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid var(--servora-border);
}

.servora-modal-section h4 {
    margin-bottom: 1rem;
}

.servora-package-price-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.9rem;
}

.servora-package-price-editor {
    display: grid;
    grid-template-columns: minmax(6.5rem, 0.7fr) repeat(4, minmax(0, 1fr));
    align-items: end;
    gap: 0.8rem;
    padding: 0.95rem;
    border-radius: 0.9rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.025);
}

.servora-package-price-editor > * {
    min-width: 0;
}

.servora-package-price-editor .form-control {
    min-width: 0;
}

.servora-package-price-editor > .d-flex {
    align-self: center;
}

.servora-package-price-editor .row {
    display: contents;
}

.servora-package-price-editor .row > [class*="col-"] {
    width: auto;
    max-width: none;
    padding: 0;
}

.servora-modal-content .form-control,
.servora-modal-content .form-select,
.servora-modal-content textarea {
    background: rgba(255, 255, 255, 0.03);
    border-color: var(--servora-border);
    color: var(--servora-text);
}

.servora-modal-content .form-control::placeholder,
.servora-modal-content textarea::placeholder {
    color: #7f8da0;
}

.servora-modal-content .form-control:focus,
.servora-modal-content .form-select:focus,
.servora-modal-content textarea:focus {
    border-color: rgba(224, 36, 36, 0.45);
    box-shadow: 0 0 0 0.25rem rgba(224, 36, 36, 0.12);
}

.servora-license-module-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.9rem;
}

.servora-license-module-card {
    position: relative;
    display: block;
    cursor: pointer;
}

.servora-license-module-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.servora-license-module-card-body {
    display: grid;
    gap: 0.25rem;
    min-height: 100%;
    padding: 1rem 1rem 1rem 3rem;
    border-radius: 1rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.03);
    position: relative;
    transition: 0.2s ease;
}

.servora-license-module-card-body::before {
    content: '';
    position: absolute;
    left: 1rem;
    top: 1rem;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 0.45rem;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.02);
}

.servora-license-module-card-body strong {
    color: var(--servora-text);
    font-size: 0.98rem;
}

.servora-license-module-card-body small {
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-license-module-card:hover .servora-license-module-card-body {
    border-color: rgba(224, 36, 36, 0.22);
    background: rgba(224, 36, 36, 0.05);
}

.servora-license-module-card input:checked + .servora-license-module-card-body {
    border-color: rgba(224, 36, 36, 0.28);
    background: linear-gradient(180deg, rgba(224, 36, 36, 0.12), rgba(224, 36, 36, 0.05));
    box-shadow: inset 0 0 0 1px rgba(224, 36, 36, 0.15);
}

.servora-license-module-card input:checked + .servora-license-module-card-body::before {
    border-color: rgba(224, 36, 36, 0.42);
    background: linear-gradient(135deg, #ff3b30, #c31717);
    box-shadow: 0 0 0 3px rgba(224, 36, 36, 0.12);
}

.servora-license-module-card input:checked + .servora-license-module-card-body::after {
    content: '✓';
    position: absolute;
    left: 1.33rem;
    top: 1rem;
    font-size: 0.82rem;
    font-weight: 800;
    color: #fff;
}

.servora-toggle-card {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.75rem 0.95rem;
    border-radius: 0.95rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.03);
    cursor: pointer;
    user-select: none;
}

.servora-toggle-card input {
    margin: 0;
}

.servora-page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.servora-header-actions {
    display: flex;
    gap: 0.75rem;
}

.servora-btn-primary,
.btn-primary {
    background: linear-gradient(135deg, #ff3b30, #c31717);
    border-color: transparent;
    box-shadow: 0 12px 28px rgba(224, 36, 36, 0.22);
}

.servora-panel,
.servora-stat-card,
.servora-auth-card {
    background: linear-gradient(180deg, rgba(18, 28, 42, 0.98), rgba(14, 23, 35, 0.98));
    border: 1px solid var(--servora-border);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
}

body.servora-body.theme-light .servora-panel,
body.servora-body.theme-light .servora-stat-card,
body.servora-body.theme-light .servora-auth-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.98));
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

.servora-stat-label {
    color: var(--servora-text-soft);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    margin-bottom: 0.85rem;
}

.servora-stat-value {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
    margin-bottom: 0.75rem;
}

.servora-stat-money {
    font-size: 1.7rem;
}

.servora-stat-change {
    font-size: 0.85rem;
}

.servora-stat-change.positive {
    color: var(--servora-success);
}

.servora-chart-placeholder {
    height: 21rem;
    position: relative;
    border-radius: 1.25rem;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(224, 36, 36, 0.16), rgba(224, 36, 36, 0.01)),
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0.01));
}

body.servora-body.theme-light .servora-chart-placeholder {
    background:
        linear-gradient(180deg, rgba(224, 36, 36, 0.1), rgba(224, 36, 36, 0.02)),
        linear-gradient(180deg, rgba(15, 23, 42, 0.02), rgba(15, 23, 42, 0.01));
}

.servora-chart-placeholder::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
    background-size: 100% 20%, 12.5% 100%;
}

.servora-chart-line {
    position: absolute;
    inset: 18% 5% 10% 5%;
    background: linear-gradient(180deg, rgba(224, 36, 36, 0.38), rgba(224, 36, 36, 0));
    clip-path: polygon(0% 88%, 8% 82%, 18% 84%, 27% 67%, 35% 55%, 44% 58%, 54% 44%, 63% 29%, 72% 35%, 81% 22%, 90% 28%, 100% 16%, 100% 100%, 0 100%);
    border-bottom: 2px solid rgba(255, 79, 79, 0.9);
}

.servora-revenue-bars {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.85rem;
    min-height: 21rem;
    align-items: end;
    padding: 1rem 0.25rem 0;
}

.servora-revenue-bar-item {
    display: grid;
    grid-template-rows: minmax(12rem, 1fr) auto auto;
    gap: 0.45rem;
    min-width: 0;
    text-align: center;
}

.servora-revenue-bar-track {
    display: flex;
    align-items: end;
    min-height: 12rem;
    border-radius: 0.75rem;
    overflow: hidden;
    background:
        linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
        rgba(255, 255, 255, 0.03);
    background-size: 100% 25%;
}

.servora-revenue-bar-track span {
    display: block;
    width: 100%;
    min-height: 0.35rem;
    border-radius: 0.75rem 0.75rem 0 0;
    background: linear-gradient(180deg, rgba(255, 86, 78, 0.92), rgba(224, 36, 36, 0.42));
    box-shadow: 0 -12px 34px rgba(224, 36, 36, 0.22);
}

.servora-revenue-bar-item strong,
.servora-revenue-bar-item small {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-revenue-bar-item small {
    color: var(--servora-text-soft);
    font-size: 0.74rem;
}

.servora-donut-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.servora-donut {
    width: 16rem;
    height: 16rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at center, #111c2a 0 34%, transparent 35%),
        conic-gradient(var(--servora-success) 0 76%, var(--servora-warning) 76% 88%, var(--servora-orange) 88% 98%, var(--servora-accent) 98% 100%);
}

.servora-donut > div {
    text-align: center;
}

.servora-donut strong {
    display: block;
    font-size: 2rem;
}

.servora-donut span {
    color: var(--servora-text-soft);
}

.servora-donut-legend {
    display: grid;
    gap: 0.8rem;
    min-width: 14rem;
}

.servora-donut-legend .dot {
    width: 0.75rem;
    height: 0.75rem;
    display: inline-block;
    border-radius: 999px;
    margin-right: 0.6rem;
}

.dot.yellow { background: var(--servora-warning); }
.dot.orange { background: var(--servora-orange); }
.dot.green { background: var(--servora-success); }
.dot.red { background: var(--servora-accent); }
.dot.blue { background: #4dabf7; }
.dot.gray { background: var(--servora-text-soft); }

.servora-table {
    color: #dfe6ef;
}

.servora-table thead th {
    color: #95a5b8;
    border-bottom-color: var(--servora-border);
}

.servora-table td {
    border-top-color: rgba(255, 255, 255, 0.05);
}

.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
}

.status-badge.yellow { background: rgba(240, 186, 45, 0.14); color: #ffd55d; }
.status-badge.orange { background: rgba(240, 139, 45, 0.14); color: #ffb061; }
.status-badge.green { background: rgba(73, 194, 107, 0.14); color: #77db90; }

.servora-insight-list {
    display: grid;
    gap: 0;
}

.servora-insight-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.servora-dashboard-side-stack {
    display: grid;
    gap: 1rem;
}

.servora-dashboard-link-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    color: var(--servora-text);
    text-decoration: none;
    padding: 0.85rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.servora-dashboard-link-row:hover {
    color: var(--servora-text);
}

.servora-dashboard-link-row span {
    display: grid;
    min-width: 0;
}

.servora-dashboard-link-row b {
    flex: 0 0 auto;
    white-space: nowrap;
    text-align: right;
}

.servora-dashboard-link-row strong,
.servora-dashboard-link-row small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-dashboard-link-row small {
    color: var(--servora-text-soft);
}

.servora-insight-item:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.servora-insight-item span {
    color: var(--servora-text-soft);
    min-width: 0;
}

.servora-insight-item strong {
    flex: 0 0 auto;
}

.servora-insight-stack {
    align-items: flex-start;
    gap: 1rem;
}

.servora-owner-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.servora-feature-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.servora-feature-grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.servora-feature-card {
    padding: 1.1rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--servora-border);
}

.servora-feature-card-link {
    display: block;
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.servora-feature-card-link:hover {
    transform: translateY(-2px);
    border-color: rgba(224, 36, 36, 0.28);
    background: rgba(224, 36, 36, 0.06);
    color: var(--servora-text);
}

.servora-feature-card h4 {
    margin-bottom: 0.55rem;
    font-size: 1rem;
}

.servora-feature-card p {
    margin-bottom: 0;
    color: var(--servora-text-soft);
    font-size: 0.92rem;
}

.servora-company-list {
    display: grid;
    gap: 1rem;
}

.servora-view-switch {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem;
    border: 1px solid var(--servora-border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.03);
    gap: 0.25rem;
}

.servora-view-switch-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 4.75rem;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    text-decoration: none;
    color: var(--servora-text-soft);
    transition: 0.2s ease;
}

.servora-view-switch-btn:hover {
    color: var(--servora-text);
    background: rgba(255, 255, 255, 0.05);
}

.servora-view-switch-btn.active {
    color: var(--servora-text);
    background: linear-gradient(135deg, rgba(224, 36, 36, 0.18), rgba(224, 36, 36, 0.08));
    box-shadow: inset 0 0 0 1px rgba(224, 36, 36, 0.18);
}

.servora-company-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1.25rem 1.35rem;
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.02));
    border: 1px solid var(--servora-border);
}

.servora-company-main {
    min-width: 0;
}

.servora-company-heading {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    margin-bottom: 1rem;
}

.servora-company-title {
    margin: 0 0 0.35rem;
    font-size: 1.16rem;
}

.servora-company-badges {
    display: inline-flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.servora-company-facts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.servora-company-fact {
    padding: 0.8rem 0.9rem;
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.servora-company-fact span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    margin-bottom: 0.2rem;
}

.servora-company-fact strong {
    color: var(--servora-text);
    font-size: 0.96rem;
}

.servora-company-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.servora-company-grid-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.servora-company-card {
    display: grid;
    gap: 1rem;
    padding: 1.25rem;
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.02));
    border: 1px solid var(--servora-border);
}

.servora-company-card-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.servora-company-card-bottom {
    display: flex;
    justify-content: flex-end;
}

.servora-risk-note {
    margin-top: 0.45rem;
    color: #ff8a82;
    font-size: 0.78rem;
    line-height: 1.35;
}

.servora-suspicious-cleanup {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    flex-wrap: wrap;
}

.servora-suspicious-cleanup .form-check-label {
    color: var(--servora-text);
    font-size: 0.84rem;
}

.servora-panel .pagination {
    margin-bottom: 0;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.servora-panel .page-link {
    min-width: 2.45rem;
    border-radius: 0.55rem;
    border: 1px solid var(--servora-border);
    background: rgba(10, 20, 35, 0.78);
    color: var(--servora-text);
    text-align: center;
}

.servora-panel .page-link:hover,
.servora-panel .page-link:focus {
    border-color: rgba(255, 59, 48, 0.45);
    background: rgba(255, 59, 48, 0.14);
    color: #ffffff;
    box-shadow: none;
}

.servora-panel .page-item.active .page-link {
    border-color: rgba(255, 59, 48, 0.7);
    background: rgba(255, 59, 48, 0.24);
    color: #ffffff;
}

.servora-panel .page-item.disabled .page-link {
    border-color: rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    color: var(--servora-text-muted);
}

.servora-empty-state {
    padding: 1.25rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed rgba(255, 255, 255, 0.12);
}

.servora-empty-state h4 {
    margin-bottom: 0.55rem;
}

.servora-empty-state p {
    margin: 0;
    color: var(--servora-text-soft);
}

.servora-vehicle-item {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    padding: 1rem 1.1rem;
}

.servora-inline-card {
    height: 100%;
    padding: 1rem 1.1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-vehicle-form {
    display: grid;
    gap: 1.35rem;
}

.servora-form-card {
    display: block;
    padding: 1.6rem;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 1rem;
    background:
        linear-gradient(180deg, rgba(18, 31, 48, 0.96), rgba(12, 23, 38, 0.96)),
        var(--servora-panel);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24);
}

body.servora-body.theme-light .servora-form-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98)),
        #fff;
    border-color: rgba(15, 23, 42, 0.1);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.servora-form-card-header {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1.2rem;
}

.servora-form-card-icon {
    width: 2.5rem;
    height: 2.5rem;
    flex: 0 0 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.85rem;
    background: rgba(224, 36, 36, 0.14);
    border: 1px solid rgba(224, 36, 36, 0.24);
    color: #ff9a9a;
}

.servora-form-card-header h3 {
    margin: 0;
    font-size: 1.05rem;
}

.servora-form-card-header p {
    margin: 0.15rem 0 0;
    color: var(--servora-text-soft);
}

.servora-service-title-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.servora-service-title-collapsed {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.servora-service-title-collapsed > div {
    min-width: 0;
}

.servora-selected-title-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    min-height: 2.35rem;
    align-items: center;
}

.servora-selected-title-list span,
.servora-selected-title-list em {
    display: inline-flex;
    align-items: center;
    min-height: 2.1rem;
    padding: 0.38rem 0.65rem;
    border-radius: 999px;
    font-size: 0.92rem;
    font-style: normal;
    font-weight: 850;
}

.servora-selected-title-list span {
    border: 1px solid rgba(224, 36, 36, 0.38);
    background: rgba(224, 36, 36, 0.14);
    color: var(--servora-text);
}

.servora-selected-title-list em {
    border: 1px dashed rgba(148, 163, 184, 0.24);
    color: var(--servora-text-soft);
}

.servora-service-title-panel {
    margin-top: 0.85rem;
    padding: 0.9rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.85rem;
    background: rgba(15, 23, 42, 0.28);
}

.servora-service-title-chip {
    cursor: pointer;
}

.servora-service-title-chip input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.servora-service-title-chip span {
    display: inline-flex;
    align-items: center;
    min-height: 2.35rem;
    padding: 0.5rem 0.75rem;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.42);
    color: var(--servora-text-soft);
    font-weight: 800;
    transition: 0.16s ease;
}

.servora-service-title-chip input:checked + span,
.servora-service-title-chip:hover span {
    border-color: rgba(224, 36, 36, 0.42);
    background: rgba(224, 36, 36, 0.14);
    color: var(--servora-text);
}

@media (max-width: 900px) {
    .servora-service-title-collapsed {
        align-items: stretch;
        flex-direction: column;
    }
}

.servora-service-history-list {
    display: grid;
    gap: 0.7rem;
}

.servora-service-history-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 0.85rem;
    align-items: center;
    padding: 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 0.8rem;
    background: rgba(15, 23, 42, 0.34);
}

.servora-service-history-item strong,
.servora-service-history-item small {
    display: block;
}

.servora-service-history-item small {
    color: var(--servora-text-soft);
}

.servora-service-history-item b {
    color: var(--servora-text);
}

.servora-vehicle-form .form-label,
.servora-vehicle-form .form-check-label {
    color: #dbe3ed;
    font-weight: 650;
}

body.servora-body.theme-light .servora-vehicle-form .form-label,
body.servora-body.theme-light .servora-vehicle-form .form-check-label {
    color: #223047;
}

.servora-vehicle-form .form-control,
.servora-vehicle-form textarea {
    min-height: 3.15rem;
    background: rgba(6, 13, 23, 0.72);
    border-color: rgba(148, 163, 184, 0.18);
    color: var(--servora-text);
}

body.servora-body.theme-light .servora-vehicle-form .form-control,
body.servora-body.theme-light .servora-vehicle-form textarea {
    background: rgba(15, 23, 42, 0.03);
    border-color: rgba(15, 23, 42, 0.12);
}

.servora-vehicle-form .form-control:focus,
.servora-vehicle-form textarea:focus {
    border-color: rgba(224, 36, 36, 0.48);
    box-shadow: 0 0 0 0.25rem rgba(224, 36, 36, 0.12);
}

.servora-vehicle-switch {
    width: 100%;
    min-height: 3.15rem;
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.65rem 0.8rem;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 0.65rem;
    background: rgba(6, 13, 23, 0.45);
}

body.servora-body.theme-light .servora-vehicle-switch {
    border-color: rgba(15, 23, 42, 0.12);
    background: rgba(15, 23, 42, 0.03);
}

.servora-form-actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 0.5rem;
}

@media (min-width: 992px) {
    .servora-form-actions {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}

.servora-auth-shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 2rem 1rem;
}

.servora-auth-card {
    max-width: 34rem;
    margin: 0 auto;
}

.servora-auth-card .form-control,
.servora-auth-card .form-select,
.servora-topbar .form-control {
    background: rgba(255, 255, 255, 0.03);
    border-color: var(--servora-border);
    color: var(--servora-text);
}

body.servora-body.theme-light .servora-auth-card .form-control,
body.servora-body.theme-light .servora-auth-card .form-select,
body.servora-body.theme-light .servora-topbar .form-control {
    background: rgba(15, 23, 42, 0.03);
}

.servora-auth-card .form-control:focus,
.servora-topbar .form-control:focus {
    border-color: rgba(224, 36, 36, 0.45);
    box-shadow: 0 0 0 0.25rem rgba(224, 36, 36, 0.12);
}

.servora-auth-card .form-label,
.servora-auth-card .form-check-label {
    color: #dbe3ed;
}

.servora-captcha-check {
    display: grid;
    grid-template-columns: max-content minmax(7rem, 1fr);
    align-items: center;
    gap: 0.75rem;
    padding: 0.85rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-captcha-check span {
    color: var(--servora-text);
    font-weight: 800;
    white-space: nowrap;
}

.servora-captcha-check .form-control {
    min-height: 2.75rem;
}

.alert-danger {
    background: rgba(224, 36, 36, 0.12);
    border-color: rgba(224, 36, 36, 0.3);
    color: #ffd9d9;
}

.alert-success {
    background: rgba(73, 194, 107, 0.12);
    border-color: rgba(73, 194, 107, 0.28);
    color: #cbf7d5;
}

@media (max-width: 991.98px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    body.servora-mobile-menu-lock {
        overflow: hidden;
        touch-action: none;
    }

    .servora-mobile-topbar {
        position: sticky;
        top: 0;
        z-index: 60;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.9rem;
        min-height: 4.4rem;
        padding: max(0.7rem, env(safe-area-inset-top)) 1rem 0.7rem;
        border-bottom: 1px solid rgba(148, 163, 184, 0.16);
        background: rgba(7, 17, 28, 0.88);
        backdrop-filter: blur(16px);
        box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
    }

    body.servora-body.theme-light .servora-mobile-topbar {
        background: rgba(255, 255, 255, 0.92);
    }

    .servora-mobile-brand {
        display: inline-flex;
        align-items: center;
        min-width: 0;
        gap: 0.75rem;
        color: var(--servora-text);
        text-decoration: none;
    }

    .servora-mobile-brand-mark {
        width: 2.35rem;
        height: 2.35rem;
        display: inline-flex;
        flex: 0 0 auto;
        align-items: center;
        justify-content: center;
        border-radius: 0.8rem;
        background: linear-gradient(135deg, #ff3b30, #9c1111);
        box-shadow: 0 10px 28px rgba(224, 36, 36, 0.28);
        color: #fff;
        font-size: 1.15rem;
        font-weight: 800;
    }

    .servora-mobile-brand span:last-child {
        display: grid;
        min-width: 0;
        line-height: 1.1;
    }

    .servora-mobile-brand strong {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        letter-spacing: 0.14rem;
        font-size: 0.94rem;
    }

    .servora-mobile-brand small {
        overflow: hidden;
        color: var(--servora-text-soft);
        font-size: 0.76rem;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .servora-mobile-menu-toggle {
        display: inline-flex;
        flex: 0 0 auto;
        width: 2.75rem;
        height: 2.75rem;
        align-items: center;
        justify-content: center;
        border: 1px solid rgba(148, 163, 184, 0.25);
        border-radius: 0.9rem;
        color: var(--servora-text);
        background: rgba(255, 255, 255, 0.04);
        box-shadow: none;
    }

    body.servora-body.theme-light .servora-mobile-menu-toggle {
        background: rgba(15, 23, 42, 0.04);
    }

    .servora-mobile-menu-backdrop {
        position: fixed;
        inset: 0;
        z-index: 65;
        display: block;
        width: 100%;
        height: 100%;
        padding: 0;
        border: 0;
        opacity: 0;
        pointer-events: none;
        background: rgba(2, 6, 12, 0.58);
        backdrop-filter: blur(4px);
        transition: opacity 0.2s ease;
    }

    html.servora-mobile-sidebar-open .servora-mobile-menu-backdrop {
        opacity: 1;
        pointer-events: auto;
    }

    .servora-sidebar {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        right: auto;
        z-index: 70;
        width: 100vw;
        max-width: 100vw;
        height: 100dvh;
        min-height: 100dvh;
        overflow: hidden;
        border-right: 1px solid rgba(148, 163, 184, 0.18);
        box-shadow: none;
        transform: translate3d(-100%, 0, 0);
        transition: transform 0.24s ease;
    }

    html.servora-mobile-sidebar-open .servora-sidebar {
        transform: translate3d(0, 0, 0);
    }

    .servora-sidebar .container-fluid {
        display: block;
        width: 100%;
        max-width: 100%;
        height: 100dvh;
        padding: 0;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }

    .servora-sidebar-head {
        display: none;
    }

    .servora-mobile-drawer-head {
        position: sticky;
        top: 0;
        z-index: 2;
        display: grid;
        grid-template-columns: minmax(0, 1fr) 2.75rem;
        align-items: center;
        width: 100%;
        gap: 0.75rem;
        padding: max(1rem, env(safe-area-inset-top)) 1rem 0.85rem;
        border-bottom: 1px solid rgba(148, 163, 184, 0.16);
        background: rgba(7, 17, 28, 0.96);
        backdrop-filter: blur(16px);
    }

    body.servora-body.theme-light .servora-mobile-drawer-head {
        background: rgba(255, 255, 255, 0.96);
    }

    .servora-mobile-drawer-brand {
        display: grid;
        grid-template-columns: 2.5rem minmax(0, 1fr);
        align-items: center;
        gap: 0.75rem;
        min-width: 0;
        color: var(--servora-text);
    }

    .servora-mobile-drawer-mark {
        width: 2.5rem;
        height: 2.5rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 0.85rem;
        background: linear-gradient(135deg, #ff3b30, #9c1111);
        box-shadow: 0 10px 28px rgba(224, 36, 36, 0.26);
        color: #fff;
        font-size: 1.18rem;
        font-weight: 800;
    }

    .servora-mobile-drawer-brand span:last-child {
        display: grid;
        min-width: 0;
        line-height: 1.1;
    }

    .servora-mobile-drawer-brand strong,
    .servora-mobile-drawer-brand small {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .servora-mobile-drawer-brand strong {
        letter-spacing: 0.14rem;
        font-size: 0.95rem;
    }

    .servora-mobile-drawer-brand small {
        color: var(--servora-text-soft);
        font-size: 0.76rem;
    }

    .servora-mobile-drawer-close {
        width: 2.75rem;
        height: 2.75rem;
        border-color: rgba(148, 163, 184, 0.24);
        border-radius: 0.9rem;
        color: var(--servora-text);
        background: rgba(255, 255, 255, 0.04);
    }

    .servora-sidebar .servora-brand {
        width: 100%;
        max-width: 100%;
    }

    .servora-sidebar .servora-brand-text strong,
    .servora-sidebar .servora-brand-text small,
    .servora-sidebar .nav-link-title,
    .servora-user-name,
    .servora-user-role {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .servora-sidebar .navbar-collapse {
        display: block;
        width: 100%;
        max-width: 100%;
        margin: 0 !important;
        padding: 0.85rem 1rem 1rem;
    }

    .servora-sidebar .navbar-nav {
        display: grid;
        width: 100%;
        max-width: 100%;
        gap: 0.25rem;
        padding-left: 0;
        margin: 0;
        list-style: none;
    }

    .servora-sidebar .nav-item {
        width: 100%;
        margin: 0;
        padding: 0;
    }

    .servora-sidebar .nav-link {
        display: grid;
        grid-template-columns: 2.15rem minmax(0, 1fr);
        align-items: center;
        width: 100%;
        max-width: 100%;
        gap: 0.75rem;
        margin: 0;
        padding: 0.86rem 0.95rem;
        border-radius: 0.8rem;
        font-size: 0.98rem;
        line-height: 1.2;
        overflow: hidden;
    }

    .servora-sidebar .nav-link-icon {
        width: 2.15rem;
        min-width: 2.15rem;
        justify-content: center;
    }

    .servora-sidebar .nav-link-title {
        min-width: 0;
    }

    .servora-brand-text strong {
        font-size: 0.95rem;
        letter-spacing: 0.16rem;
    }

    .servora-brand-text small {
        font-size: 0.64rem;
    }

    .servora-user-card {
        padding: 0.85rem;
        margin-bottom: 0.75rem;
        border-radius: 0.9rem;
    }

    .servora-sidebar-footer {
        width: 100%;
        padding: 0.5rem 1rem max(1rem, env(safe-area-inset-bottom));
        margin-top: 0;
    }

    .servora-logout-btn {
        min-height: 2.9rem;
    }

    .servora-page-wrapper {
        margin-left: 0 !important;
        max-width: 100vw;
        width: 100%;
    }

    .page-body {
        padding-top: 0;
    }

    .servora-page-header {
        padding-top: 0.35rem;
    }

    .servora-page-header,
    .servora-donut-wrap {
        flex-direction: column;
        align-items: stretch;
    }

    .servora-content {
        padding: 1rem;
    }

    .servora-search .form-control {
        min-width: 0;
    }

    .servora-search-panel {
        position: fixed;
        left: 1rem;
        right: 1rem;
        top: 5.25rem;
        max-height: calc(100vh - 6.25rem);
    }

    .servora-topbar .container-xl {
        grid-template-columns: 1fr;
    }

    .servora-search-results-grid {
        grid-template-columns: 1fr;
    }

    .servora-search-panel-row,
    .servora-search-result-row {
        grid-template-columns: 5.75rem minmax(0, 1fr);
    }

    .servora-feature-grid {
        grid-template-columns: 1fr;
    }

    .servora-license-package-summary,
    .servora-license-module-grid,
    .servora-package-price-grid,
    .servora-price-pill-row,
    .servora-license-board,
    .servora-license-create-strip .card-body,
    .servora-license-create-form,
    .servora-license-store-grid {
        grid-template-columns: 1fr;
    }

    .servora-license-package-head,
    .servora-license-editor-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .servora-license-current {
        flex-direction: column;
    }

    .servora-license-current-badges {
        justify-content: flex-start;
    }

    .servora-company-grid-cards,
    .servora-company-row,
    .servora-company-heading,
    .servora-company-facts {
        grid-template-columns: 1fr;
    }

    .servora-company-card-top,
    .servora-company-actions {
        justify-content: flex-start;
    }
}

.servora-legal-shell {
    max-width: 960px;
    margin: 0 auto;
}

.servora-legal-card {
    background: linear-gradient(180deg, rgba(18, 28, 42, 0.98), rgba(14, 23, 35, 0.98));
    border: 1px solid var(--servora-border);
    border-radius: 1.5rem;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
}

.servora-legal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    color: var(--servora-text-soft);
    font-size: 0.9rem;
}

.servora-legal-note {
    padding: 1rem 1.1rem;
    border: 1px solid rgba(240, 186, 45, 0.22);
    border-radius: 1rem;
    background: rgba(240, 186, 45, 0.08);
    color: #f5e4ac;
}

.servora-legal-card h1,
.servora-legal-card h2,
.servora-legal-card h3 {
    color: var(--servora-text);
}

.servora-legal-card h2 {
    margin-top: 2rem;
    margin-bottom: 0.85rem;
    font-size: 1.2rem;
}

.servora-legal-card h3 {
    margin-top: 1.25rem;
    margin-bottom: 0.65rem;
    font-size: 1rem;
}

.servora-legal-card p,
.servora-legal-card li {
    color: #dbe4ef;
    line-height: 1.7;
}

.servora-legal-list {
    padding-left: 1.1rem;
}

body.servora-body.theme-light .servora-legal-note {
    color: #7a5800;
    background: rgba(240, 186, 45, 0.12);
}

.servora-settings-tabs {
    border-bottom: 0;
}

.servora-settings-tabs .nav-link {
    color: var(--servora-text-soft);
    border: 0;
    border-radius: 0.85rem;
    margin-right: 0.5rem;
}

.servora-settings-tabs .nav-link.active,
.servora-settings-tabs .nav-link:hover {
    color: var(--servora-text);
    background: rgba(224, 36, 36, 0.12);
}

.servora-settings-sidecard {
    padding: 1.25rem;
    border-radius: 1.1rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--servora-border);
}

.servora-settings-sidecard h3 {
    margin-bottom: 0.5rem;
}

.servora-readonly-grid {
    display: grid;
    gap: 0.85rem;
}

.servora-readonly-field {
    display: grid;
    gap: 0.25rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-readonly-field span {
    color: var(--servora-text-muted);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-readonly-field strong {
    color: var(--servora-text);
    font-size: 1rem;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.servora-permission-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.servora-permission-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 4rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    font-weight: 700;
}

.servora-permission-item.is-disabled {
    color: var(--servora-text-muted);
    opacity: 0.58;
}

.servora-permission-item.is-enabled {
    border-color: rgba(34, 197, 94, 0.35);
    background: rgba(34, 197, 94, 0.08);
}

.servora-permission-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 1.65rem;
    width: 1.65rem;
    height: 1.65rem;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.26);
    color: var(--servora-text-muted);
}

.servora-permission-item.is-enabled .servora-permission-status {
    color: #4ade80;
    border-color: rgba(74, 222, 128, 0.45);
    background: rgba(34, 197, 94, 0.15);
}

.servora-time-action-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(20rem, 0.85fr) minmax(18rem, 0.7fr);
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.servora-time-hero,
.servora-time-action-card,
.servora-time-entry,
.servora-time-off-card {
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-time-hero {
    display: flex;
    align-items: center;
    min-height: 14rem;
    padding: 1.25rem;
    background:
        linear-gradient(135deg, rgba(59, 130, 246, 0.13), rgba(224, 36, 36, 0.08)),
        rgba(255, 255, 255, 0.03);
}

.servora-time-hero.is-active {
    background:
        linear-gradient(135deg, rgba(34, 197, 94, 0.14), rgba(59, 130, 246, 0.07)),
        rgba(255, 255, 255, 0.03);
}

.servora-time-hero h2 {
    margin: 0.45rem 0;
    font-size: 1.6rem;
}

.servora-time-hero p {
    max-width: 38rem;
    margin: 0;
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-time-state {
    display: inline-flex;
    width: fit-content;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    color: #93c5fd;
    background: rgba(59, 130, 246, 0.12);
    font-weight: 800;
}

.servora-time-hero.is-active .servora-time-state {
    color: #4ade80;
    background: rgba(34, 197, 94, 0.13);
}

.servora-time-action-card {
    display: grid;
    align-content: start;
    gap: 0.9rem;
    padding: 1rem;
}

.servora-time-action-card h3 {
    margin: 0;
}

.servora-location-status {
    min-height: 1.25rem;
    color: var(--servora-text-soft);
    font-size: 0.86rem;
}

.servora-time-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.34fr);
    gap: 1rem;
    align-items: start;
}

.servora-section-title {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.servora-section-title h2 {
    margin: 0;
    font-size: 1.15rem;
}

.servora-section-title p {
    margin: 0.25rem 0 0;
    color: var(--servora-text-soft);
}

.servora-bulk-delete-form {
    flex: 0 0 auto;
}

.servora-time-entry-list,
.servora-time-off-list {
    display: grid;
    gap: 0.9rem;
}

.servora-time-entry,
.servora-time-off-card {
    padding: 1rem;
}

.servora-time-entry-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 0.9rem;
}

.servora-time-entry-head h3 {
    margin: 0;
    font-size: 1.05rem;
}

.servora-time-entry-head p {
    margin: 0.2rem 0 0;
    color: var(--servora-text-soft);
}

.servora-time-readonly-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-time-readonly-grid > div {
    display: grid;
    gap: 0.25rem;
    padding: 0.8rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-time-readonly-grid span {
    color: var(--servora-text-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-time-readonly-grid strong,
.servora-time-readonly-grid small {
    overflow-wrap: anywhere;
}

.servora-time-readonly-grid small,
.servora-time-note {
    color: var(--servora-text-soft);
}

.servora-time-edit-form {
    display: grid;
    gap: 1rem;
}

.servora-time-map-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.servora-map-btn {
    white-space: nowrap;
    padding-inline: 0.65rem;
}

.servora-note-btn {
    white-space: nowrap;
    padding-inline: 0.65rem;
}

.servora-time-control-grid {
    display: grid;
    grid-template-columns: minmax(18rem, 0.8fr) minmax(18rem, 0.75fr) minmax(0, 1.35fr);
    gap: 1rem;
    margin-bottom: 1rem;
    align-items: stretch;
}

.servora-time-control-grid.is-owner {
    grid-template-columns: minmax(19rem, 0.5fr) minmax(0, 1fr);
}

.servora-time-control-grid > * {
    min-width: 0;
}

.servora-time-filter-card,
.servora-time-compact-action,
.servora-time-owner-actions {
    padding: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-time-compact-action,
.servora-time-owner-actions {
    display: grid;
    gap: 0.75rem;
}

.servora-time-compact-action.is-active {
    border-color: rgba(34, 197, 94, 0.32);
    background: rgba(34, 197, 94, 0.06);
}

.servora-time-compact-action span,
.servora-time-owner-actions span {
    display: block;
    color: var(--servora-text-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-time-compact-action strong,
.servora-time-owner-actions strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--servora-text);
    font-size: 1rem;
}

.servora-time-off-request-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.servora-time-request-panel {
    margin-bottom: 1rem;
}

.servora-time-request-list {
    display: grid;
    gap: 0.75rem;
}

.servora-time-request-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(18rem, 0.55fr);
    gap: 1rem;
    align-items: start;
    padding: 0.9rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-time-request-card > div:first-child {
    display: grid;
    gap: 0.15rem;
    min-width: 0;
}

.servora-time-request-card strong,
.servora-time-request-card span,
.servora-time-request-card small {
    overflow: hidden;
    text-overflow: ellipsis;
}

.servora-time-request-card span {
    color: var(--servora-text-soft);
    font-weight: 800;
}

.servora-time-request-card small {
    color: var(--servora-text-muted);
}

.servora-time-request-actions {
    display: grid;
    gap: 0.55rem;
}

.servora-time-request-actions > div {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
}

.servora-time-filter-card {
    display: grid;
    gap: 0.9rem;
}

.servora-time-control-grid > .servora-time-filter-card:only-child {
    grid-column: 1 / -1;
}

.servora-time-filter-form,
.servora-time-export-form {
    display: grid;
    grid-template-columns: minmax(11rem, 1fr) minmax(7rem, 0.42fr) minmax(7rem, 0.42fr) auto;
    gap: 0.75rem;
    align-items: end;
}

.servora-time-export-form {
    grid-template-columns: minmax(7rem, 0.28fr) minmax(7rem, 0.28fr) auto;
    justify-content: end;
    padding-top: 0.85rem;
    border-top: 1px solid var(--servora-border);
}

.servora-time-filter-form > *,
.servora-time-export-form > * {
    min-width: 0;
}

.servora-time-table-wrap {
    overflow-x: auto;
}

.servora-time-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 0.55rem;
    min-width: 74rem;
}

.servora-time-table th {
    padding: 0 0.8rem 0.35rem;
    color: var(--servora-text-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.servora-time-table .servora-select-col {
    width: 2.5rem;
    text-align: center;
}

.servora-time-table td {
    padding: 0.55rem 0.75rem;
    border-top: 1px solid var(--servora-border);
    border-bottom: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.03);
    vertical-align: middle;
}

.servora-time-table td:first-child {
    border-left: 1px solid var(--servora-border);
    border-radius: 0.85rem 0 0 0.85rem;
    font-weight: 800;
    white-space: nowrap;
}

.servora-time-table td:last-child {
    border-right: 1px solid var(--servora-border);
    border-radius: 0 0.85rem 0.85rem 0;
}

.servora-time-table tr.is-time-off td {
    background: rgba(245, 158, 11, 0.06);
}

.servora-table-action-btn {
    white-space: nowrap;
}

.servora-time-modal .modal-dialog {
    transition: transform 0.18s ease-out, opacity 0.18s ease-out;
    transform: translateY(10px) scale(0.98);
    opacity: 0;
}

.servora-time-modal.show .modal-dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.servora-time-modal-content .modal-header {
    align-items: flex-start;
}

.servora-time-modal-content .modal-title {
    margin: 0;
}

.servora-time-modal-content .modal-header p {
    margin: 0.25rem 0 0;
    color: var(--servora-text-soft);
}

.servora-time-modal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.servora-time-modal-wide {
    grid-column: 1 / -1;
}

.servora-note-view {
    display: grid;
    gap: 0.9rem;
}

.servora-note-view div {
    padding: 0.95rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.035);
}

.servora-note-view span {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--servora-text-muted);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-note-view p {
    margin: 0;
    color: var(--servora-text);
    line-height: 1.45;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

@media (max-width: 767.98px) {
    .servora-time-modal-grid {
        grid-template-columns: 1fr;
    }
}

.servora-license-market {
    display: grid;
    gap: 1.35rem;
}

.servora-license-current {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.2rem;
    border-radius: 1rem;
    border: 1px solid var(--servora-border);
    background:
        linear-gradient(135deg, rgba(224, 36, 36, 0.12), rgba(29, 78, 216, 0.08)),
        rgba(255, 255, 255, 0.025);
}

.servora-license-current-main {
    display: flex;
    gap: 0.9rem;
    align-items: flex-start;
}

.servora-license-current h3,
.servora-license-store-card h4 {
    margin: 0;
}

.servora-license-current p,
.servora-license-store-card p {
    margin: 0.35rem 0 0;
    color: var(--servora-text-soft);
    line-height: 1.45;
}

.servora-license-current-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.5rem;
}

.servora-license-store-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.servora-license-store-card {
    position: relative;
    display: grid;
    gap: 1.05rem;
    align-content: start;
    padding: 1.1rem;
    border-radius: 1rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.03);
    overflow: hidden;
}

.servora-license-store-card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, rgba(224, 36, 36, 0.9), rgba(224, 36, 36, 0.14));
}

.servora-license-store-card.is-basic::before {
    background: linear-gradient(90deg, rgba(76, 201, 240, 0.9), rgba(76, 201, 240, 0.14));
}

.servora-license-store-card.is-pro::before {
    background: linear-gradient(90deg, rgba(111, 207, 151, 0.9), rgba(111, 207, 151, 0.14));
}

.servora-license-store-card.is-ultimate::before {
    background: linear-gradient(90deg, rgba(180, 116, 255, 0.9), rgba(180, 116, 255, 0.14));
}

.servora-license-store-card.is-current {
    border-color: rgba(73, 194, 107, 0.28);
    box-shadow: inset 0 0 0 1px rgba(73, 194, 107, 0.12);
}

.servora-license-store-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}

.servora-license-store-head > div {
    min-width: 0;
}

.servora-license-store-head .badge {
    flex: 0 0 auto;
    max-width: 100%;
    white-space: nowrap;
}

.servora-license-store-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-license-store-meta > div {
    padding: 0.75rem 0.8rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.servora-license-store-meta span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
}

.servora-license-store-meta strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--servora-text);
}

.servora-license-period-list {
    display: grid;
    gap: 0.55rem;
}

.servora-license-period-option {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(5.5rem, 0.9fr) minmax(6rem, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0.8rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.025);
    color: var(--servora-text);
    text-align: left;
    cursor: pointer;
}

.servora-license-period-option:hover {
    border-color: rgba(224, 36, 36, 0.28);
    background: rgba(224, 36, 36, 0.08);
}

.servora-license-period-option:disabled {
    opacity: 0.62;
    cursor: not-allowed;
}

.servora-license-period-option > span {
    display: grid;
    gap: 0.1rem;
}

.servora-license-period-price {
    text-align: right;
}

.servora-license-buy-badge {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 2.4rem;
    padding: 0.5rem 0.85rem;
    border-radius: 0.65rem;
    background: linear-gradient(135deg, #ff3b30, #d92525);
    color: #fff;
    font-weight: 800;
    white-space: nowrap;
    box-shadow: 0 10px 24px rgba(224, 36, 36, 0.2);
}

.servora-license-period-option:disabled .servora-license-buy-badge {
    background: rgba(255, 255, 255, 0.08);
    color: var(--servora-text-soft);
    box-shadow: none;
}

.servora-license-period-option small,
.servora-license-period-option del {
    color: var(--servora-text-soft);
}

.servora-license-history {
    display: grid;
    gap: 0.65rem;
}

.servora-license-history-panel {
    display: grid;
    gap: 0.85rem;
    padding: 1.1rem;
    border: 1px solid var(--servora-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.025);
}

.servora-license-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.servora-license-history-tabs {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.45rem;
    padding: 0.25rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.025);
}

.servora-license-history-tabs .nav-item {
    display: flex;
}

.servora-license-history-tabs .nav-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.35rem;
    padding: 0.5rem 0.85rem;
    border-radius: 0.65rem;
    color: var(--servora-text-soft);
    font-weight: 700;
    white-space: nowrap;
}

.servora-license-history-tabs .nav-link span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.35rem;
    height: 1.35rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--servora-text-soft);
    font-size: 0.75rem;
}

.servora-license-history-tabs .nav-link.active,
.servora-license-history-tabs .nav-link:hover {
    color: var(--servora-text);
    background: rgba(224, 36, 36, 0.14);
}

.servora-license-history-tabs .nav-link.active span {
    color: #fff;
    background: rgba(224, 36, 36, 0.82);
}

.servora-license-history-tab-content {
    min-width: 0;
}

.servora-license-history-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 0.95rem;
    border-radius: 0.85rem;
    border: 1px solid var(--servora-border);
    background: rgba(255, 255, 255, 0.025);
}

.servora-company-admin-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(22rem, 0.75fr);
    gap: 1.25rem;
    align-items: start;
}

.servora-company-admin-main,
.servora-company-admin-side {
    min-width: 0;
}

.servora-company-access-form {
    display: grid;
    grid-template-columns: minmax(16rem, 0.8fr) minmax(16rem, 1fr);
    gap: 1rem;
    align-items: end;
}

.servora-company-access-form .servora-company-meta,
.servora-company-access-form .servora-company-license-note,
.servora-company-access-form > div:last-child {
    grid-column: 1 / -1;
}

.servora-company-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.servora-company-meta > div {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
    padding: 0.8rem 0.9rem;
    border-radius: 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
}

.servora-company-meta span {
    color: var(--servora-text-soft);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
}

.servora-company-meta strong {
    color: var(--servora-text);
    overflow-wrap: anywhere;
}

.servora-company-license-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    padding: 0.9rem;
    border: 1px solid rgba(96, 165, 250, 0.2);
    border-radius: 0.9rem;
    background: linear-gradient(135deg, rgba(29, 78, 216, 0.12), rgba(255, 255, 255, 0.025));
}

.servora-company-license-summary > div {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
}

.servora-company-license-summary span {
    color: var(--servora-text-soft);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
}

.servora-company-license-summary strong {
    color: var(--servora-text);
    overflow-wrap: anywhere;
}

.servora-company-license-note {
    display: grid;
    gap: 0.25rem;
    padding: 0.9rem 1rem;
    border-radius: 0.85rem;
    border: 1px solid rgba(96, 165, 250, 0.22);
    background: rgba(29, 78, 216, 0.1);
}

.servora-company-license-note span {
    color: var(--servora-text-soft);
}

.servora-system-settings-form {
    display: grid;
    gap: 1rem;
}

.servora-system-setting-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(14rem, 0.32fr);
    gap: 1rem;
    align-items: end;
    padding: 1rem;
    border: 1px solid var(--servora-border);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.03);
}

.servora-system-setting-preview {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(59, 130, 246, 0.22);
    border-radius: 0.85rem;
    background: rgba(59, 130, 246, 0.08);
}

.servora-system-setting-preview span {
    color: var(--servora-text-soft);
    font-weight: 800;
}

.servora-system-setting-preview strong {
    color: var(--servora-text);
    font-size: 1.25rem;
}

.servora-license-history-note {
    margin-top: 0.35rem;
    color: var(--servora-text-soft);
    font-size: 0.85rem;
    overflow-wrap: anywhere;
}

@media (max-width: 991.98px) {
    .servora-license-current {
        flex-direction: column;
    }

    .servora-license-current-badges {
        justify-content: flex-start;
    }

    .servora-license-section-head {
        flex-direction: column;
    }

    .servora-license-history-tabs {
        width: 100%;
        justify-content: flex-start;
    }

    .servora-package-price-editor {
        grid-template-columns: 1fr;
    }

    .servora-system-setting-row {
        grid-template-columns: 1fr;
    }

    .servora-company-license-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-package-price-editor .row {
        display: flex;
    }

    .servora-package-price-editor .row > [class*="col-"] {
        width: 50%;
        padding-right: calc(var(--tblr-gutter-x, 1.5rem) * 0.5);
        padding-left: calc(var(--tblr-gutter-x, 1.5rem) * 0.5);
    }

    .servora-license-store-grid {
        grid-template-columns: 1fr;
    }

    .servora-permission-list {
        grid-template-columns: 1fr;
    }

    .servora-time-action-grid,
    .servora-time-control-grid,
    .servora-time-layout,
    .servora-time-readonly-grid,
    .servora-time-request-card {
        grid-template-columns: 1fr;
    }

    .servora-time-request-actions > div {
        justify-content: flex-start;
    }

    .servora-time-filter-form,
    .servora-time-export-form {
        grid-template-columns: 1fr;
        justify-content: stretch;
    }

    .servora-license-period-option {
        grid-template-columns: 1fr;
    }

    .servora-license-period-price {
        text-align: left;
    }

    .servora-company-admin-layout,
    .servora-company-access-form,
    .servora-company-meta {
        grid-template-columns: 1fr;
    }
}

.servora-company-logo-preview {
    display: grid;
    place-items: center;
    min-height: 12rem;
    border-radius: 1rem;
    border: 1px dashed rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.02);
}

.servora-company-logo-preview img {
    max-width: 100%;
    max-height: 10rem;
    object-fit: contain;
}

.servora-company-logo-fallback {
    width: 5rem;
    height: 5rem;
    border-radius: 1.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 800;
    background: linear-gradient(135deg, #ff3b30, #9c1111);
    color: #fff;
    box-shadow: 0 12px 32px rgba(224, 36, 36, 0.24);
}

.servora-panel .form-control,
.servora-panel .form-select,
.servora-panel textarea {
    background: rgba(255, 255, 255, 0.03);
    border-color: var(--servora-border);
    color: var(--servora-text);
}

body.servora-body.theme-light .servora-panel .form-control,
body.servora-body.theme-light .servora-panel .form-select,
body.servora-body.theme-light .servora-panel textarea {
    background: rgba(15, 23, 42, 0.03);
}

.servora-panel .form-control::placeholder,
.servora-panel textarea::placeholder {
    color: #7f8da0;
}

.servora-panel .form-control:focus,
.servora-panel .form-select:focus,
.servora-panel textarea:focus {
    border-color: rgba(224, 36, 36, 0.45);
    box-shadow: 0 0 0 0.25rem rgba(224, 36, 36, 0.12);
}

.servora-panel .form-label,
.servora-panel .form-check-label {
    color: #dbe3ed;
}

.servora-roadmap-shell {
    height: 100%;
}

.servora-roadmap-nav {
    display: grid;
    gap: 1rem;
    max-height: calc(100vh - 18rem);
    overflow: auto;
    padding-right: 0.25rem;
}

.servora-roadmap-feature {
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.02);
    transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.servora-roadmap-feature.is-active {
    border-color: rgba(224, 36, 36, 0.3);
    background: linear-gradient(180deg, rgba(224, 36, 36, 0.1), rgba(224, 36, 36, 0.03));
}

.servora-roadmap-feature-head {
    padding: 0.95rem 1rem 0.8rem;
}

.servora-roadmap-feature-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    text-decoration: none;
    font-weight: 700;
    color: var(--servora-text);
}

.servora-roadmap-sub-list {
    display: grid;
    gap: 0.55rem;
    padding: 0 0.8rem 0.8rem;
}

.servora-roadmap-sub-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0.9rem;
    border: 1px solid transparent;
    background: rgba(255, 255, 255, 0.025);
    color: var(--servora-text-soft);
    text-decoration: none;
}

.servora-roadmap-sub-link:hover,
.servora-roadmap-sub-link.is-active {
    color: var(--servora-text);
    border-color: rgba(224, 36, 36, 0.2);
    background: rgba(224, 36, 36, 0.08);
}

.servora-roadmap-empty-sub {
    padding: 0 1rem 1rem;
    color: var(--servora-text-soft);
    font-size: 0.85rem;
}

.servora-roadmap-sub-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.servora-roadmap-overview-card {
    display: block;
    padding: 1rem;
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.servora-roadmap-overview-card:hover {
    transform: translateY(-2px);
    border-color: rgba(224, 36, 36, 0.24);
    background: rgba(224, 36, 36, 0.05);
}

body.servora-body.theme-light .servora-roadmap-feature,
body.servora-body.theme-light .servora-roadmap-overview-card,
body.servora-body.theme-light .servora-roadmap-sub-link {
    background: rgba(15, 23, 42, 0.02);
}

body.servora-body.theme-light .servora-panel .form-label,
body.servora-body.theme-light .servora-panel .form-check-label {
    color: #334155;
}

@media (max-width: 1199.98px) {
    .servora-roadmap-nav {
        max-height: none;
    }
}

@media (max-width: 767.98px) {
    .servora-roadmap-sub-cards {
        grid-template-columns: 1fr;
    }
}

.servora-admin-company-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.25rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 1rem;
    background:
        radial-gradient(circle at top right, rgba(224, 36, 36, 0.16), transparent 34%),
        linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(30, 41, 59, 0.72));
}

.servora-admin-company-hero > div:first-child {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.servora-admin-company-avatar {
    display: grid;
    place-items: center;
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, #ef4444, #b91c1c);
    box-shadow: 0 1rem 2rem rgba(224, 36, 36, 0.24);
    color: #fff;
    font-size: 1.5rem;
    font-weight: 800;
}

.servora-admin-company-kicker {
    color: var(--servora-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-admin-company-hero h2 {
    margin: 0.15rem 0;
    color: var(--servora-text);
    font-size: 1.35rem;
}

.servora-admin-company-hero p {
    margin: 0;
    color: var(--servora-text-muted);
}

.servora-admin-company-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(5.5rem, 1fr));
    gap: 0.65rem;
}

.servora-admin-company-metrics > div {
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.75rem;
    background: rgba(15, 23, 42, 0.45);
}

.servora-admin-company-metrics span {
    display: block;
    color: var(--servora-text-soft);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.servora-admin-company-metrics strong {
    display: block;
    margin-top: 0.25rem;
    color: var(--servora-text);
    font-size: 1.35rem;
}

.servora-admin-company-tabs {
    gap: 0.5rem;
    padding: 0.35rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 1rem;
    background: rgba(15, 23, 42, 0.62);
}

.servora-admin-company-tabs .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border: 0;
    border-radius: 0.75rem;
    color: var(--servora-text-muted);
    font-weight: 750;
}

.servora-admin-company-tabs .nav-link span {
    display: inline-grid;
    place-items: center;
    min-width: 1.35rem;
    height: 1.35rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.14);
    color: var(--servora-text-soft);
    font-size: 0.75rem;
}

.servora-admin-company-tabs .nav-link.active,
.servora-admin-company-tabs .nav-link:hover {
    background: rgba(224, 36, 36, 0.16);
    color: var(--servora-text);
}

.servora-admin-company-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(24rem, 0.85fr);
    gap: 1rem;
}

.servora-admin-edit-form .form-label {
    font-weight: 750;
}

.servora-admin-record-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.servora-admin-record-card {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    min-height: 100%;
    padding: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 1rem;
    background:
        radial-gradient(circle at top right, rgba(224, 36, 36, 0.1), transparent 42%),
        rgba(15, 23, 42, 0.72);
}

.servora-admin-record-title {
    color: var(--servora-text);
    font-size: 1.05rem;
    font-weight: 800;
}

.servora-admin-record-facts {
    display: grid;
    gap: 0.35rem;
    color: var(--servora-text-muted);
}

.servora-admin-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.servora-admin-linked-list {
    display: grid;
    gap: 0.45rem;
    padding: 0.75rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    font-size: 0.86rem;
}

.servora-admin-linked-list span,
.servora-admin-linked-list .is-muted {
    color: var(--servora-text-soft);
}

.servora-admin-table-wrap {
    width: 100%;
    overflow-x: auto;
}

.servora-admin-table {
    width: 100%;
    min-width: 58rem;
    border-collapse: separate;
    border-spacing: 0 0.55rem;
}

.servora-admin-table th {
    padding: 0 0.8rem 0.35rem;
    color: var(--servora-text-soft);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.servora-admin-table td {
    padding: 0.85rem 0.8rem;
    background: rgba(15, 23, 42, 0.7);
    border-top: 1px solid rgba(148, 163, 184, 0.12);
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
    color: var(--servora-text);
    vertical-align: middle;
}

.servora-admin-table td:first-child {
    border-left: 1px solid rgba(148, 163, 184, 0.12);
    border-radius: 0.75rem 0 0 0.75rem;
}

.servora-admin-table td:last-child {
    border-right: 1px solid rgba(148, 163, 184, 0.12);
    border-radius: 0 0.75rem 0.75rem 0;
}

.servora-admin-checks,
.servora-admin-permission-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.servora-admin-checks label,
.servora-admin-permission-grid label {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.65rem 0.75rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.035);
    color: var(--servora-text);
    font-weight: 700;
}

.servora-admin-permission-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 1199.98px) {
    .servora-admin-company-hero,
    .servora-admin-company-grid {
        grid-template-columns: 1fr;
    }

    .servora-admin-company-hero {
        flex-direction: column;
        align-items: stretch;
    }

    .servora-admin-record-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .servora-admin-company-metrics,
    .servora-admin-record-grid,
    .servora-admin-permission-grid {
        grid-template-columns: 1fr;
    }
}

.servora-quote-form {
    display: grid;
    gap: 22px;
    min-width: 0;
    width: 100%;
}

.servora-quote-header {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.servora-quote-actionbar {
    align-items: center;
    background: rgba(15, 23, 42, .52);
    border: 1px solid rgba(148, 163, 184, .18);
    border-radius: 14px;
    box-shadow: 0 16px 38px rgba(0, 0, 0, .18);
    display: flex;
    gap: 4px;
    max-width: 100%;
    padding: 5px;
    white-space: nowrap;
}

.servora-quote-actionbar form {
    display: contents;
}

.servora-quote-action {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 10px;
    color: #cbd5e1;
    display: inline-flex;
    font-size: .84rem;
    font-weight: 700;
    gap: 7px;
    line-height: 1;
    min-height: 36px;
    padding: 0 12px;
    text-decoration: none;
    transition: background .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.servora-quote-action:hover {
    background: rgba(255, 255, 255, .06);
    color: #f8fafc;
    transform: translateY(-1px);
}

.servora-quote-action .icon {
    flex: 0 0 18px;
}

.servora-quote-action.is-muted {
    color: #94a3b8;
}

.servora-quote-action.is-blue {
    color: #60a5fa;
}

.servora-quote-action.is-red {
    background: rgba(239, 68, 68, .14);
    color: #fecaca;
    box-shadow: inset 0 0 0 1px rgba(239, 68, 68, .2);
}

.servora-quote-action.is-red:hover {
    background: rgba(239, 68, 68, .22);
    color: #fff;
}

.servora-quote-action.is-green {
    background: rgba(34, 197, 94, .14);
    color: #bbf7d0;
    box-shadow: inset 0 0 0 1px rgba(34, 197, 94, .2);
}

.servora-quote-action.is-green:hover {
    background: rgba(34, 197, 94, .22);
    color: #fff;
}

.servora-quote-action.is-danger-outline {
    color: #f87171;
    box-shadow: inset 0 0 0 1px rgba(248, 113, 113, .36);
}

.servora-quote-action.is-danger-outline:hover {
    background: rgba(239, 68, 68, .14);
    color: #fecaca;
}

.servora-quote-action:disabled {
    cursor: not-allowed;
    opacity: .45;
    transform: none;
}

.servora-quote-action.is-disabled,
.servora-quote-action[aria-disabled="true"] {
    cursor: not-allowed;
    opacity: .45;
    pointer-events: none;
    transform: none;
}

.servora-quote-action-separator {
    align-self: stretch;
    background: rgba(148, 163, 184, .18);
    display: inline-flex;
    margin: 5px 3px;
    width: 1px;
}

.servora-quote-actionbar.is-table {
    border-radius: 12px;
    box-shadow: none;
    justify-content: flex-end;
    padding: 4px;
    width: max-content;
}

.servora-quote-actionbar.is-table .servora-quote-action {
    font-size: .78rem;
    min-height: 32px;
    padding: 0 9px;
}

.servora-quote-actionbar.is-table .servora-quote-action-separator {
    margin-block: 4px;
}

.servora-quote-actionbar.is-document {
    box-shadow: none;
    flex-wrap: wrap;
    justify-content: flex-end;
    width: max-content;
}

.servora-quote-actionbar.is-document .servora-quote-action {
    font-size: .78rem;
    min-height: 32px;
    padding: 0 9px;
}

.servora-quote-actionbar.is-document .servora-quote-action-separator {
    margin-block: 4px;
}

.servora-table-actions-cell {
    white-space: nowrap;
}

.servora-attachment-indicator {
    align-items: center;
    color: #60a5fa;
    display: inline-flex;
    font-size: .78rem;
    font-weight: 750;
    gap: 5px;
}

.servora-attachment-indicator .icon {
    flex: 0 0 16px;
}

body.servora-body.theme-light .servora-quote-actionbar {
    background: rgba(255, 255, 255, .82);
    border-color: rgba(15, 23, 42, .1);
}

body.servora-body.theme-light .servora-quote-action {
    color: #475569;
}

body.servora-body.theme-light .servora-quote-action:hover {
    background: rgba(15, 23, 42, .06);
    color: #0f172a;
}

@media (max-width: 1199.98px) {
    .servora-quote-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .servora-quote-actionbar {
        overflow-x: auto;
        width: 100%;
    }
}

@media (max-width: 1399.98px) {
    .servora-work-order-head {
        align-items: stretch !important;
    }

    .servora-work-order-head > div:first-child {
        min-width: 0;
    }

    .servora-work-order-head .servora-quote-actionbar {
        width: 100%;
    }

    .servora-work-order-modern .servora-quote-item-row {
        grid-template-columns: repeat(3, minmax(0, 1fr)) 38px;
    }

    .servora-work-order-modern .servora-quote-item-row > div:first-of-type {
        grid-column: 1 / -1;
    }

    .servora-work-order-modern .servora-quote-item-row.is-service,
    .servora-work-order-modern .servora-quote-item-row.is-compact-price {
        grid-template-columns: repeat(3, minmax(0, 1fr)) 38px;
    }
}

.servora-live-results {
    position: absolute;
    z-index: 30;
    right: 12px;
    left: 12px;
    top: calc(100% + 6px);
    display: grid;
    gap: 6px;
    padding: 8px;
    border: 1px solid rgba(148, 163, 184, .2);
    border-radius: 12px;
    background: #101827;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .28);
}

.servora-live-result {
    width: 100%;
    padding: 10px 12px;
    border: 0;
    border-radius: 8px;
    background: rgba(255, 255, 255, .04);
    color: #e5edf8;
    font-size: 13px;
    text-align: left;
}

.servora-live-result:hover {
    background: rgba(255, 59, 48, .16);
}

.servora-live-result.muted {
    color: #94a3b8;
    cursor: default;
}

.servora-vehicle-mini {
    align-items: center;
    background: rgba(15, 23, 42, .42);
    border: 1px solid rgba(148, 163, 184, .18);
    border-radius: 12px;
    display: flex;
    gap: 14px;
    justify-content: space-between;
    min-height: 54px;
    padding: 8px 10px 8px 14px;
}

.servora-vehicle-mini strong,
.servora-vehicle-mini span {
    display: block;
}

.servora-vehicle-mini strong {
    color: #eef4ff;
    font-size: .92rem;
}

.servora-vehicle-mini span {
    color: #94a3b8;
    font-size: .8rem;
    margin-top: 2px;
}

@media (max-width: 575.98px) {
    .servora-vehicle-mini {
        align-items: stretch;
        flex-direction: column;
    }
}

.servora-quote-items {
    display: grid;
    gap: 12px;
}

.servora-work-order-modern {
    --wo-card-bg: rgba(13, 24, 38, .72);
    --wo-card-bg-soft: rgba(16, 29, 45, .62);
    --wo-border: rgba(148, 163, 184, .16);
    --wo-border-strong: rgba(148, 163, 184, .24);
    --wo-muted: #93a1b4;
    --wo-field-bg: rgba(8, 17, 30, .76);
    --wo-field-border: rgba(148, 163, 184, .22);
    font-size: 14px;
    min-width: 0;
    max-width: 100%;
    overflow-x: clip;
}

.servora-work-order-modern .page-title {
    font-size: 1.35rem;
    line-height: 1.15;
    letter-spacing: 0;
}

.servora-work-order-modern .page-subtitle {
    margin-top: .25rem;
    color: var(--wo-muted);
    font-size: .86rem;
}

.servora-work-order-modern .btn {
    min-height: 2.25rem;
    padding: .45rem .82rem;
    border-radius: .52rem;
    font-size: .84rem;
    font-weight: 650;
}

.servora-work-order-modern .btn-sm {
    min-height: 2rem;
    padding: .34rem .62rem;
    font-size: .78rem;
}

.servora-work-order-modern .row.g-4 {
    --tblr-gutter-x: 1rem;
    --tblr-gutter-y: 1rem;
}

.servora-work-order-overview {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.servora-work-order-card {
    min-height: 92px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 8px;
    padding: 14px 15px;
    border: 1px solid var(--wo-border);
    border-radius: 12px;
    background:
        linear-gradient(145deg, rgba(18, 31, 48, .76), rgba(8, 17, 30, .72)),
        var(--servora-panel);
    box-shadow: 0 12px 26px rgba(0, 0, 0, .16);
}

.servora-work-order-card.is-money {
    border-color: rgba(255, 59, 48, .24);
    background:
        linear-gradient(145deg, rgba(72, 22, 30, .48), rgba(12, 23, 38, .78)),
        var(--servora-panel);
}

.servora-work-order-card-kicker {
    color: #94a3b8;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .075em;
    text-transform: uppercase;
}

.servora-work-order-card strong {
    display: block;
    color: var(--servora-text);
    font-size: 1rem;
    line-height: 1.2;
}

.servora-work-order-card small {
    color: var(--servora-text-soft);
    font-size: .78rem;
}

.servora-work-order-modern .servora-form-card {
    padding: 1.1rem 1.15rem;
    border-color: var(--wo-border);
    border-radius: 13px;
    background:
        linear-gradient(180deg, rgba(15, 28, 44, .76), rgba(9, 18, 31, .74)),
        var(--servora-panel);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .16);
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

.servora-work-order-modern .servora-form-card + .servora-form-card,
.servora-work-order-modern .servora-quote-grid,
.servora-work-order-modern .servora-form-actions {
    margin-top: 1rem;
}

.servora-work-order-modern .servora-form-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1rem;
}

.servora-work-order-modern .servora-form-card-header > div {
    min-width: 0;
}

.servora-work-order-modern .servora-form-card-header .btn {
    flex: 0 0 auto;
}

.servora-work-order-modern .servora-form-card-header h3 {
    font-size: .98rem;
    line-height: 1.2;
    letter-spacing: 0;
}

.servora-work-order-modern .servora-form-card-header p {
    max-width: 54rem;
    margin-top: .28rem;
    font-size: .82rem;
    line-height: 1.35;
    color: var(--wo-muted);
}

.servora-work-order-modern .form-label,
.servora-work-order-modern .form-check-label,
.servora-work-order-modern .servora-quote-summary span {
    margin-bottom: .38rem;
    color: #dce5ef;
    font-size: .8rem;
    font-weight: 650;
    letter-spacing: 0;
}

.servora-work-order-modern .form-control,
.servora-work-order-modern .form-select {
    min-height: 2.65rem;
    padding: .58rem .74rem;
    border-color: var(--wo-field-border);
    border-radius: .55rem;
    background-color: var(--wo-field-bg);
    color: var(--servora-text);
    font-size: .88rem;
}

.servora-work-order-modern textarea.form-control {
    min-height: 5.4rem;
}

.servora-work-order-modern .form-control:read-only {
    color: #d4dce7;
    background-color: rgba(8, 17, 30, .55);
}

.servora-work-order-modern .form-control:focus,
.servora-work-order-modern .form-select:focus {
    border-color: rgba(96, 165, 250, .52);
    box-shadow: 0 0 0 .18rem rgba(59, 130, 246, .12);
}

.servora-quote-item-row {
    display: grid;
    grid-template-columns: minmax(140px, 1.3fr) minmax(72px, .46fr) minmax(92px, .62fr) minmax(92px, .62fr) minmax(96px, .62fr) minmax(100px, .66fr) 38px;
    gap: 8px;
    align-items: end;
    padding: 11px;
    border: 1px solid rgba(148, 163, 184, .14);
    border-radius: 11px;
    background: rgba(10, 20, 34, .56);
    min-width: 0;
    max-width: 100%;
}

.servora-quote-item-row > div {
    min-width: 0;
}

.servora-work-order-modern .servora-quote-item-row {
    border-color: var(--wo-border);
    background: rgba(8, 17, 30, .48);
}

.servora-quote-item-row.is-service {
    grid-template-columns: minmax(160px, 1.5fr) minmax(80px, .48fr) minmax(96px, .62fr) minmax(108px, .66fr) 38px;
}

.servora-quote-item-row.is-compact-price {
    grid-template-columns: minmax(160px, 1.5fr) minmax(80px, .48fr) minmax(96px, .62fr) minmax(108px, .66fr) 38px;
}

.servora-quote-remove {
    width: 2.35rem;
    height: 2.65rem;
    padding: 0;
    font-size: 1.08rem;
    line-height: 1;
}

.servora-quote-grid,
.servora-public-quote-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
    gap: 16px;
    min-width: 0;
}

.servora-quote-summary-card {
    align-self: start;
}

.servora-quote-summary,
.servora-public-summary {
    display: grid;
    gap: 7px;
}

.servora-quote-summary > div,
.servora-public-summary > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid rgba(148, 163, 184, .12);
}

.servora-quote-summary span,
.servora-public-summary span {
    color: #94a3b8;
}

.servora-quote-summary strong,
.servora-public-summary strong {
    color: #f8fafc;
    font-size: .9rem;
}

.servora-quote-summary .is-total,
.servora-public-summary .is-total {
    margin-top: 4px;
    padding: 12px;
    border: 1px solid rgba(255, 59, 48, .28);
    border-radius: 10px;
    background: rgba(255, 59, 48, .1);
}

.servora-quote-summary .is-total strong,
.servora-public-summary .is-total strong {
    font-size: 1.15rem;
}

.servora-quote-discount-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 12px !important;
}

.servora-work-order-doc-grid {
    display: grid;
    grid-template-columns: minmax(280px, .55fr) minmax(0, 1fr);
    gap: 14px;
}

.servora-collapsible-head {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.servora-collapse-toggle {
    align-items: center;
    background: rgba(15, 23, 42, .56);
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 12px;
    color: #cbd5e1;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: .8rem;
    font-weight: 800;
    gap: 8px;
    min-height: 36px;
    padding: 0 12px;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.servora-collapse-toggle:hover {
    background: rgba(30, 41, 59, .78);
    border-color: rgba(96, 165, 250, .38);
    color: #f8fafc;
    transform: translateY(-1px);
}

.servora-collapse-toggle .icon {
    transition: transform .18s ease;
}

.servora-collapse-toggle[aria-expanded="true"] .icon {
    transform: rotate(180deg);
}

.servora-signature-content {
    overflow: hidden;
}

.servora-signature-head {
    align-items: flex-end;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin-bottom: 12px;
}

.servora-signature-head strong {
    color: #f8fafc;
    display: block;
    font-size: clamp(1.35rem, 2.2vw, 2.25rem);
    line-height: 1.05;
}

.servora-signature-kicker {
    color: #94a3b8;
    display: block;
    font-size: .78rem;
    font-weight: 850;
    letter-spacing: .08em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.servora-signature-customer {
    color: #cbd5e1;
    font-size: .95rem;
    font-weight: 800;
    text-align: right;
}

.servora-signature-pad-wrap {
    background:
        linear-gradient(transparent 94%, rgba(148, 163, 184, .13) 95%),
        rgba(248, 250, 252, .98);
    background-size: 100% 34px;
    border: 1px solid rgba(148, 163, 184, .4);
    border-radius: 14px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .75), 0 20px 50px rgba(0, 0, 0, .2);
    height: min(48vh, 390px);
    min-height: 280px;
    overflow: hidden;
    position: relative;
}

.servora-signature-pad {
    display: block;
    height: 100%;
    touch-action: none;
    width: 100%;
}

.servora-signature-placeholder {
    color: rgba(100, 116, 139, .45);
    font-size: clamp(2.2rem, 7vw, 5rem);
    font-weight: 850;
    left: 50%;
    pointer-events: none;
    position: absolute;
    text-align: center;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}

body.servora-body.theme-light .servora-signature-head strong {
    color: #0f172a;
}

body.servora-body.theme-light .servora-signature-customer {
    color: #475569;
}

.servora-work-order-upload,
.servora-work-order-doc {
    padding: 12px;
    border: 1px solid var(--wo-border);
    border-radius: 11px;
    background: rgba(8, 17, 30, .48);
}

.servora-work-order-doc-list {
    display: grid;
    gap: 10px;
}

.servora-work-order-doc-list-title {
    color: var(--servora-text);
    font-weight: 800;
}

.servora-work-order-doc {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.servora-work-order-doc strong,
.servora-work-order-doc small {
    display: block;
}

.servora-work-order-doc small {
    margin-top: 4px;
    color: var(--servora-text-soft);
}

.servora-work-order-doc-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.servora-quote-discount-row label {
    display: grid;
    gap: 6px;
}

.servora-quotes-table td {
    vertical-align: middle;
}

.servora-quotes-table th:last-child,
.servora-quotes-table td:last-child {
    min-width: 23rem;
}

.servora-public-quote-body .servora-auth-shell {
    min-height: 100vh;
    padding: 32px 16px;
    background: #0b1220;
}

.servora-public-quote {
    width: min(1120px, 100%);
    margin: 0 auto;
    display: grid;
    gap: 20px;
}

.servora-public-quote-header,
.servora-public-card,
.servora-public-actions {
    border: 1px solid rgba(148, 163, 184, .16);
    border-radius: 14px;
    background: linear-gradient(180deg, #111a2b 0%, #0d1525 100%);
    box-shadow: 0 20px 60px rgba(0, 0, 0, .25);
}

.servora-public-quote-header {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 28px;
}

.servora-public-quote-header span {
    color: #94a3b8;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.servora-public-quote-header h1 {
    margin: 8px 0 6px;
    color: #fff;
    font-size: 34px;
}

.servora-public-quote-header p {
    margin: 0;
    color: #9fb0cc;
}

.servora-public-quote-header > div:last-child {
    display: grid;
    align-content: center;
    justify-items: end;
    gap: 10px;
}

.servora-public-quote-header > div:last-child strong {
    color: #fff;
    font-size: 28px;
}

.servora-public-card {
    padding: 22px;
}

.servora-public-card h2 {
    margin: 0 0 14px;
    color: #fff;
    font-size: 17px;
}

.servora-public-card p {
    margin: 0 0 8px;
    color: #9fb0cc;
}

.servora-public-card strong {
    color: #fff;
}

.servora-navigation-card {
    display: grid;
    align-content: start;
}

.servora-navigation-card .btn {
    width: fit-content;
    margin-top: 8px;
}

.servora-public-table-wrap {
    overflow-x: auto;
}

.servora-public-table {
    width: 100%;
    min-width: 680px;
    border-collapse: separate;
    border-spacing: 0;
}

.servora-public-table th,
.servora-public-table td {
    padding: 13px 14px;
    border-bottom: 1px solid rgba(148, 163, 184, .12);
    color: #d9e2f2;
    text-align: left;
}

.servora-public-table th {
    color: #94a3b8;
    font-size: 12px;
    text-transform: uppercase;
}

.servora-public-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 18px;
}

body.servora-body.theme-light .servora-live-results,
body.servora-body.theme-light .servora-live-result,
body.servora-body.theme-light .servora-quote-item-row,
body.servora-body.theme-light .servora-work-order-upload,
body.servora-body.theme-light .servora-work-order-doc {
    background: #ffffff;
    color: #1f2937;
}

body.servora-body.theme-light .servora-work-order-card {
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .08);
}

body.servora-body.theme-light .servora-work-order-modern {
    --wo-card-bg: #ffffff;
    --wo-card-bg-soft: #f8fafc;
    --wo-border: rgba(15, 23, 42, .1);
    --wo-border-strong: rgba(15, 23, 42, .16);
    --wo-muted: #64748b;
    --wo-field-bg: #ffffff;
    --wo-field-border: rgba(15, 23, 42, .14);
}

body.servora-body.theme-light .servora-collapse-toggle {
    background: rgba(255, 255, 255, .82);
    border-color: rgba(15, 23, 42, .12);
    color: #475569;
}

body.servora-body.theme-light .servora-collapse-toggle:hover {
    background: #ffffff;
    border-color: rgba(37, 99, 235, .28);
    color: #0f172a;
}

body.servora-body.theme-light .servora-work-order-modern .servora-form-card {
    background: #ffffff;
    border-color: var(--wo-border);
    box-shadow: 0 10px 24px rgba(15, 23, 42, .07);
}

body.servora-body.theme-light .servora-work-order-modern .form-label,
body.servora-body.theme-light .servora-work-order-modern .form-check-label,
body.servora-body.theme-light .servora-work-order-modern .servora-quote-summary span {
    color: #334155;
}

body.servora-body.theme-light .servora-work-order-modern .form-control,
body.servora-body.theme-light .servora-work-order-modern .form-select {
    background-color: #ffffff;
    border-color: var(--wo-field-border);
    color: #0f172a;
}

body.servora-body.theme-light .servora-work-order-modern .form-control:read-only {
    background-color: #f8fafc;
    color: #334155;
}

.servora-ocr-loading {
    align-items: center;
    background: rgba(8, 13, 24, .48);
    border-radius: inherit;
    bottom: 0;
    display: flex;
    justify-content: center;
    left: 0;
    padding: 24px;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 5;
}

.servora-ocr-loader-box {
    align-items: center;
    background: rgba(15, 23, 42, .9);
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 18px;
    box-shadow: 0 18px 52px rgba(0, 0, 0, .34);
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 240px;
    padding: 24px 26px;
    text-align: center;
}

.servora-ocr-loading span {
    color: #9fb0cc;
    font-size: .86rem;
}

.servora-ocr-content {
    transition: filter .2s ease, opacity .2s ease;
}

.servora-ocr-content.is-blurred {
    filter: blur(3px);
    opacity: .62;
    pointer-events: none;
}

.servora-mailbox {
    background: linear-gradient(135deg, rgba(15, 23, 42, .86), rgba(24, 16, 34, .74));
    border: 1px solid rgba(148, 163, 184, .16);
    border-radius: 16px;
    display: grid;
    grid-template-columns: minmax(280px, 380px) minmax(0, 1fr);
    min-height: 560px;
    overflow: hidden;
}

.servora-mailbox-list {
    border-right: 1px solid rgba(148, 163, 184, .14);
    max-height: 680px;
    overflow-y: auto;
}

.servora-mailbox-list-head {
    align-items: center;
    backdrop-filter: blur(16px);
    background: rgba(11, 18, 32, .9);
    border-bottom: 1px solid rgba(148, 163, 184, .14);
    display: flex;
    justify-content: space-between;
    padding: 18px 20px;
    position: sticky;
    top: 0;
    z-index: 1;
}

.servora-mailbox-list-head strong {
    color: #f8fafc;
    font-size: 1rem;
}

.servora-mailbox-list-head span {
    align-items: center;
    background: rgba(248, 113, 113, .14);
    border: 1px solid rgba(248, 113, 113, .24);
    border-radius: 999px;
    color: #fecaca;
    display: inline-flex;
    font-size: .82rem;
    font-weight: 700;
    justify-content: center;
    min-width: 34px;
    padding: 3px 9px;
}

.servora-mini-action {
    background: rgba(248, 113, 113, .14);
    border: 1px solid rgba(248, 113, 113, .28);
    border-radius: 10px;
    color: #fecaca;
    font-size: .85rem;
    font-weight: 800;
    padding: 6px 12px;
    text-decoration: none;
}

.servora-mini-action:hover {
    background: rgba(248, 113, 113, .2);
    color: #ffffff;
}

.servora-mailbox-item {
    border-bottom: 1px solid rgba(148, 163, 184, .1);
    color: #cbd5e1;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 16px 18px;
    text-decoration: none;
    transition: background .18s ease, border-color .18s ease;
}

.servora-mailbox-item:hover {
    background: rgba(255, 255, 255, .04);
    color: #f8fafc;
}

.servora-mailbox-item.is-active {
    background: rgba(248, 113, 113, .12);
    box-shadow: inset 4px 0 0 #f87171;
    color: #ffffff;
}

.servora-mailbox-item.is-unread .servora-mailbox-item-main strong::before {
    background: #60a5fa;
    border-radius: 999px;
    content: "";
    display: inline-block;
    height: 8px;
    margin-right: 8px;
    vertical-align: 1px;
    width: 8px;
}

.servora-mailbox-item-main {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.servora-mailbox-item-main strong,
.servora-mailbox-item-main small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-mailbox-item-main strong {
    color: inherit;
    font-size: .98rem;
}

.servora-mailbox-item-main small,
.servora-mailbox-item time {
    color: #94a3b8;
    font-size: .83rem;
}

.servora-mailbox-detail {
    display: flex;
    flex-direction: column;
    gap: 22px;
    min-width: 0;
    padding: 30px;
}

.servora-mailbox-detail-head {
    align-items: flex-start;
    border-bottom: 1px solid rgba(148, 163, 184, .14);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding-bottom: 20px;
}

.servora-mailbox-detail-head h2 {
    color: #f8fafc;
    font-size: clamp(1.6rem, 2.5vw, 2.2rem);
    margin: 4px 0 0;
}

.servora-mailbox-detail-head time {
    color: #94a3b8;
    flex: 0 0 auto;
    font-size: .92rem;
}

.servora-mailbox-body {
    color: #dbeafe;
    font-size: 1.02rem;
    line-height: 1.75;
    max-width: 900px;
    white-space: pre-line;
}

.servora-mailbox-empty,
.servora-mailbox-detail-empty {
    align-items: center;
    color: #94a3b8;
    display: flex;
    gap: 10px;
    justify-content: center;
    min-height: 220px;
    padding: 24px;
    text-align: center;
}

.servora-service-request-mailbox {
    min-height: 620px;
}

.servora-request-compose {
    max-width: 980px;
}

.servora-service-request-meta {
    align-items: center;
    color: #94a3b8;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.servora-service-thread {
    display: grid;
    gap: 14px;
    max-width: 980px;
}

.servora-service-attachments {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}

.servora-request-image {
    background: rgba(15, 23, 42, .42);
    border: 1px solid rgba(148, 163, 184, .18);
    border-radius: 12px;
    color: #cbd5e1;
    display: grid;
    gap: 10px;
    overflow: hidden;
    padding: 10px;
    text-decoration: none;
}

.servora-request-image:hover {
    border-color: rgba(59, 130, 246, .48);
    color: #f8fafc;
}

.servora-request-image img {
    aspect-ratio: 4 / 3;
    border-radius: 8px;
    display: block;
    object-fit: cover;
    width: 100%;
}

.servora-request-image span {
    font-size: .82rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.servora-request-reply {
    border: 1px solid rgba(148, 163, 184, .14);
    border-radius: 12px;
    margin-bottom: 12px;
    padding: 14px 16px;
}

.servora-request-reply.is-company {
    background: rgba(59, 130, 246, .09);
}

.servora-request-reply.is-customer {
    background: rgba(255, 255, 255, .035);
}

.servora-request-reply > div {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.servora-request-reply strong {
    color: #f8fafc;
}

.servora-request-reply span {
    color: #94a3b8;
    font-size: .82rem;
}

.servora-request-reply p {
    color: #dbeafe;
    line-height: 1.65;
    margin: 10px 0 0;
    white-space: pre-line;
}

.servora-portal-reply {
    background: rgba(59, 130, 246, .08);
    border: 1px solid rgba(96, 165, 250, .18);
    border-radius: 12px;
    margin-top: 12px;
    padding: 12px 14px;
}

.servora-portal-reply strong {
    color: #f8fafc;
    display: block;
}

.servora-portal-reply small {
    color: #94a3b8;
    display: block;
    margin-top: 2px;
}

.servora-portal-reply p {
    color: #dbeafe;
    line-height: 1.55;
    margin: 8px 0 0;
    white-space: pre-line;
}

.servora-time-modal-content .modal-body {
    position: relative;
}

.servora-ocr-loader-mark {
    align-items: center;
    animation: servoraOcrPulse 1.1s ease-in-out infinite;
    background: linear-gradient(145deg, #ff3b30, #bd1f2d);
    border-radius: 14px;
    box-shadow: 0 0 0 0 rgba(255, 59, 48, .45);
    color: #fff;
    display: inline-flex;
    flex: 0 0 54px;
    font-weight: 800;
    font-size: 1.35rem;
    height: 54px;
    justify-content: center;
    width: 54px;
}

@keyframes servoraOcrPulse {
    0% {
        box-shadow: 0 0 0 0 rgba(255, 59, 48, .45);
        transform: scale(1);
    }

    70% {
        box-shadow: 0 0 0 12px rgba(255, 59, 48, 0);
        transform: scale(1.04);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(255, 59, 48, 0);
        transform: scale(1);
    }
}

@media (max-width: 1100px) {
    .servora-work-order-overview,
    .servora-work-order-doc-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .servora-quote-item-row,
    .servora-quote-item-row.is-service {
        grid-template-columns: repeat(2, minmax(0, 1fr)) 42px;
    }

    .servora-quote-grid,
    .servora-public-quote-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .servora-inventory-stat-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .75rem;
    }

    .servora-inventory-stat-grid > * {
        max-width: none;
        padding-left: 0;
        padding-right: 0;
        width: 100%;
    }

    .servora-inventory-stat-grid .servora-stat-card .card-body {
        padding: .9rem;
    }

    .servora-inventory-stat-grid .servora-stat-label {
        font-size: .72rem;
        overflow-wrap: anywhere;
    }

    .servora-inventory-stat-grid .servora-stat-value {
        font-size: 1.75rem;
        line-height: 1.05;
    }

    .servora-section-title {
        align-items: stretch;
        flex-direction: column;
    }

    .servora-work-order-list-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        overflow-x: visible;
        white-space: normal;
        width: 100%;
    }

    .servora-work-order-list-actions .servora-quote-action,
    .servora-work-order-list-actions form {
        justify-content: center;
        width: 100%;
    }

    .servora-work-order-list-actions .servora-quote-action-separator {
        display: none;
    }

    .servora-work-order-row-actions {
        align-items: stretch;
        display: grid;
        grid-template-columns: 1fr;
        min-width: 9.5rem;
        overflow-x: visible;
        white-space: normal;
        width: 100%;
    }

    .servora-work-order-row-actions .servora-quote-action {
        justify-content: flex-start;
        width: 100%;
    }

    .servora-table-actions-cell {
        white-space: normal;
    }

    .servora-work-order-overview,
    .servora-work-order-doc-grid {
        grid-template-columns: 1fr;
    }

    .servora-work-order-doc {
        align-items: stretch;
        flex-direction: column;
    }

    .servora-work-order-doc-actions {
        justify-content: stretch;
    }

    .servora-work-order-doc-actions .servora-quote-actionbar.is-document,
    .servora-work-order-doc-actions .btn,
    .servora-work-order-doc-actions form {
        width: 100%;
    }

    .servora-quote-actionbar.is-document {
        justify-content: flex-start;
        overflow-x: auto;
    }

    .servora-collapsible-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .servora-signature-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .servora-signature-customer {
        text-align: left;
    }

    .servora-signature-pad-wrap {
        height: 58vh;
        min-height: 320px;
    }

    .servora-quote-item-row,
    .servora-quote-discount-row {
        grid-template-columns: 1fr !important;
    }

    .servora-quote-remove {
        width: 100%;
    }

    .servora-public-quote-header,
    .servora-public-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .servora-public-quote-header > div:last-child {
        justify-items: start;
    }

    .servora-mailbox {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .servora-mailbox-list {
        border-right: 0;
        max-height: 300px;
    }

    .servora-mailbox-detail {
        border-top: 1px solid rgba(148, 163, 184, .14);
        padding: 22px;
    }

    .servora-mailbox-detail-head {
        flex-direction: column;
    }
}
