@charset "UTF-8";

:root {
    --av-green: #b3f000;
    --av-dark: #181b1c;
    --av-dark-soft: #24292b;
    --av-panel: #ffffff;
    --av-panel-soft: #f4f7f1;
    --av-text: #202425;
    --av-muted: #6e787b;
    --av-border: #d9dfd3;
    --av-danger: #a92e2e;
    --av-success: #2a7a3b;
    --av-shadow: 0 18px 50px rgba(0, 0, 0, 0.08);
    --av-action-gap: 12px;
}

html {
    color-scheme: light;
}

@font-face {
    font-family: 'roboto-light';
    src: url('../fonts/roboto/Roboto-Light.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'roboto-thin';
    src: url('../fonts/roboto/Roboto-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'lequire-demo';
    src: url('../fonts/lequire/Lequire.woff2') format('woff2'),
         url('../fonts/lequire/Lequire.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
    background: linear-gradient(180deg, #eef2e8 0%, #ffffff 55%);
    color: var(--av-text);
    font-family: 'roboto-light', Arial, sans-serif;
    overflow-x: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    max-width: 100%;
    display: block;
}

button,
input,
select,
textarea {
    font: inherit;
}

.app-shell {
    min-height: 100vh;
    min-height: 100dvh;
}

.topbar {
    display: none;
    align-items: center;
    gap: 16px;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 64px;
    padding: 0 16px;
    background: linear-gradient(180deg, #1a1d1e 0%, #24292b 100%);
    border-bottom: 1px solid rgba(179, 240, 0, 0.16);
    z-index: 120;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

.topbar-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.06);
    cursor: pointer;
    flex-shrink: 0;
}

.topbar-toggle-icon {
    display: inline-grid;
    gap: 4px;
}

.topbar-toggle-icon span {
    display: block;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: #fff;
}

.topbar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.topbar-brand img:first-child {
    width: auto;
    height: 30px;
    max-width: 34px;
    object-fit: contain;
}

.topbar-brand img:last-child {
    width: 114px;
    max-width: 100%;
}

.sidebar-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(24, 27, 28, 0.42);
    display: none;
    z-index: 95;
}

.sidebar-backdrop.is-visible {
    display: block;
}

.sidebar {
    --sidebar-pad-x: 22px;
    --sidebar-pad-y: clamp(16px, 2.4dvh, 28px);
    --sidebar-icon-box-size: clamp(24px, 3.1dvh, 30px);
    --sidebar-icon-glyph-size: clamp(16px, 2.2dvh, 18px);
    width: 280px;
    background: linear-gradient(180deg, #1a1d1e 0%, #262c2d 100%);
    color: #fff;
    padding: var(--sidebar-pad-y) var(--sidebar-pad-x);
    display: grid;
    grid-template-rows: auto auto auto minmax(0, 1fr);
    gap: 24px;
    border-right: 2px solid rgba(179, 240, 0, 0.14);
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    height: 100dvh;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior-y: contain;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.sidebar::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
}

.sidebar-flow {
    display: flex;
    flex-direction: column;
    gap: clamp(10px, 1.8dvh, 18px);
    min-height: 100%;
}

.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.sidebar-view-button {
    width: clamp(34px, 4.2dvh, 40px);
    height: clamp(34px, 4.2dvh, 40px);
    padding: 0;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.sidebar-view-button:hover,
.sidebar-view-button.is-collapsed-state {
    background: rgba(179, 240, 0, 0.16);
    border-color: rgba(179, 240, 0, 0.42);
    color: #b3f000;
}

.sidebar-view-preview {
    display: grid;
    gap: 3px;
    width: 18px;
}

.sidebar-view-preview span {
    display: block;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
}

.sidebar-view-preview-full {
    display: none;
}

.sidebar-view-preview-alt {
    display: grid;
}

.sidebar-view-preview-full span:nth-child(1) {
    width: 18px;
}

.sidebar-view-preview-full span:nth-child(2) {
    width: 14px;
}

.sidebar-view-preview-full span:nth-child(3) {
    width: 18px;
}

.sidebar-view-preview-icons {
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
}

.sidebar-view-preview-icons span {
    width: 4px;
    height: 14px;
}

.sidebar.is-collapsed .sidebar-view-preview-full {
    display: grid;
}

.sidebar.is-collapsed .sidebar-view-preview-alt {
    display: none;
}

.sidebar-close {
    display: none;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    width: 38px;
    height: 38px;
    cursor: pointer;
    font-size: 24px;
    line-height: 1;
}

.sidebar-user {
    display: flex;
    gap: 14px;
    padding: clamp(10px, 1.8dvh, 16px);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
}

.sidebar-user-mark {
    width: clamp(30px, 4dvh, 38px);
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    flex-shrink: 0;
}

.sidebar-user-copy {
    min-width: 0;
}

.sidebar-user-name {
    font-family: 'roboto-thin', Arial, sans-serif;
    font-size: clamp(16px, 2.2dvh, 18px);
}

.sidebar-user-meta {
    color: rgba(255, 255, 255, 0.62);
    font-size: 12px;
}

.sidebar-profile-link {
    display: inline-block;
    margin-top: 8px;
    color: rgba(179, 240, 0, 0.92);
    font-size: 13px;
    font-weight: bold;
}

.sidebar-profile-link.is-active {
    text-decoration: underline;
}

.sidebar-group-switch {
    display: grid;
    gap: 8px;
    padding: clamp(10px, 1.8dvh, 14px) clamp(12px, 1.8dvh, 16px);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.sidebar-group-switch-label {
    color: rgba(255, 255, 255, 0.66);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sidebar-group-switch select {
    width: 100%;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    padding: 10px 12px;
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.sidebar-menu-scroll {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-inline: calc(-1 * var(--sidebar-pad-x));
    padding-bottom: 8px;
}

.nav-item,
.logout-button {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: clamp(9px, 1.4dvh, 12px) calc(var(--sidebar-pad-x) + 14px);
    border-radius: 0;
    color: #f5f7f0;
    background: transparent;
    border: 1px solid transparent;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
    position: relative;
}

.nav-item-label {
    flex: 1;
    min-width: 0;
}

.nav-badge {
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    border-radius: 999px;
    background: #d7263d;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 18px rgba(215, 38, 61, 0.28);
    flex-shrink: 0;
}

.nav-icon {
    width: var(--sidebar-icon-box-size);
    height: var(--sidebar-icon-box-size);
    border-radius: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.nav-item img,
.logout-button img {
    width: var(--sidebar-icon-glyph-size);
    height: var(--sidebar-icon-glyph-size);
    filter: brightness(0) saturate(100%) invert(97%) sepia(4%) saturate(207%) hue-rotate(180deg) brightness(114%) contrast(89%);
    opacity: 0.92;
    transition: filter 0.2s ease, opacity 0.2s ease;
}

.nav-item:hover,
.logout-button:hover,
.nav-item.is-active {
    background: #b3f000;
    border-color: #b3f000;
    color: #151718;
}

.nav-item:hover .nav-icon,
.logout-button:hover .nav-icon,
.nav-item.is-active .nav-icon {
    background: transparent;
}

.nav-item:hover img,
.logout-button:hover img,
.nav-item.is-active img {
    filter: brightness(0) saturate(100%) invert(0%);
    opacity: 1;
}

.sidebar-logout {
    margin-top: 6px;
    padding-top: 0;
    border-top: 0;
}

.logout-button {
    width: 100%;
    background: rgba(255, 255, 255, 0.04);
    cursor: pointer;
}

.page-shell {
    min-width: 0;
    min-height: 100vh;
    min-height: 100dvh;
    margin-left: 280px;
    width: calc(100% - 280px);
}

.app-shell.sidebar-collapsed .sidebar {
    width: 88px;
    --sidebar-pad-x: 14px;
    --sidebar-pad-y: clamp(14px, 2dvh, 20px);
    padding: 20px var(--sidebar-pad-x);
}

.app-shell.sidebar-collapsed .page-shell {
    margin-left: 88px;
    width: calc(100% - 88px);
}

.sidebar.is-collapsed .sidebar-flow {
    gap: 16px;
}

.sidebar.is-collapsed .sidebar-user {
    display: none;
}

.sidebar.is-collapsed .sidebar-user-copy,
.sidebar.is-collapsed .sidebar-group-switch,
.sidebar.is-collapsed .nav-item-label,
.sidebar.is-collapsed .logout-label {
    display: none;
}

.sidebar.is-collapsed .nav-item,
.sidebar.is-collapsed .logout-button {
    justify-content: center;
    padding: 12px var(--sidebar-pad-x);
}

.sidebar.is-collapsed .nav-icon {
    width: clamp(38px, 5dvh, 52px);
    height: clamp(38px, 5dvh, 52px);
    border-radius: 16px;
}

.sidebar.is-collapsed .nav-item img,
.sidebar.is-collapsed .logout-button img {
    width: clamp(22px, 3.4dvh, 36px);
    height: clamp(22px, 3.4dvh, 36px);
}

.sidebar.is-collapsed .nav-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 10px;
}

.sidebar.is-collapsed .sidebar-logout {
    padding-top: 8px;
}

.page-content {
    padding: 28px;
}

.page-intro {
    margin-bottom: 26px;
}

.page-intro h1,
.auth-card h1 {
    margin: 0 0 10px;
    font-family: 'roboto-thin', Arial, sans-serif;
    font-size: 36px;
    letter-spacing: 0.01em;
}

.auth-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.auth-card-header h1 {
    flex: 1 1 auto;
}

.auth-settings-button {
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    margin-top: 2px;
}

.auth-settings-button span {
    display: block;
    font-size: 24px;
    line-height: 1;
}

.auth-settings-modal-card {
    width: min(520px, calc(100vw - 28px));
}

.auth-login-prefix {
    display: inline-block;
    font-size: 26px;
}

.auth-login-brand-word {
    display: block;
    margin-top: 2px;
    font-family: 'lequire-demo', 'roboto-thin', Arial, sans-serif;
    letter-spacing: 0.04em;
}

.page-intro p,
.auth-card p {
    margin: 0;
    color: var(--av-muted);
    max-width: 720px;
}

.overview-intro {
    margin-bottom: 18px;
}

.overview-announcement-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 14px 18px;
    margin-bottom: 18px;
    padding: 16px 20px;
    border: 1px solid rgba(179, 240, 0, 0.26);
    background:
        linear-gradient(135deg, rgba(179, 240, 0, 0.16), rgba(179, 240, 0, 0.04)),
        var(--av-panel);
}

.overview-announcement-copy {
    display: grid;
    gap: 4px;
}

.overview-announcement-copy strong {
    font-size: 18px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-announcement-copy span {
    color: var(--av-muted);
    font-size: 14px;
}

.overview-announcement-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.overview-hero-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 18px;
    margin-bottom: 18px;
}

.overview-welcome-card,
.overview-group-card {
    display: grid;
    gap: 10px;
    padding: 18px 20px;
    position: relative;
    overflow: hidden;
}

.overview-group-card {
    min-height: 148px;
    align-content: space-between;
    background: none;
    border-color: transparent;
    isolation: isolate;
}

.overview-group-card::before {
    content: "";
    position: absolute;
    inset: -2px;
    border-radius: inherit;
    background-image:
        var(--overview-group-overlay, linear-gradient(90deg, rgba(255, 255, 255, 0.97) 0%, rgba(255, 255, 255, 0.9) 18%, rgba(255, 255, 255, 0.48) 36%, rgba(255, 255, 255, 0.12) 54%, rgba(255, 255, 255, 0) 68%)),
        var(--overview-group-image);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    z-index: 0;
    transform: scale(1.01);
    transform-origin: center center;
}

.overview-kicker {
    color: var(--av-green);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 12px;
    font-weight: bold;
}

.overview-stat-strip,
.overview-group-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.overview-stat-pill,
.overview-group-meta span {
    padding: 8px 12px;
    border-radius: 12px;
    background: var(--av-panel-soft);
    border: 1px solid var(--av-border);
}

.overview-stat-pill strong {
    display: block;
    font-size: 18px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-stat-pill span {
    color: var(--av-muted);
    font-size: 12px;
}

.overview-group-media {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    align-items: center;
    position: relative;
    z-index: 1;
}

.overview-group-copy {
    max-width: 420px;
}

.overview-group-media h2 {
    margin: 0 0 4px;
    font-size: 24px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-group-media p {
    margin: 0;
    color: rgba(32, 36, 37, 0.82);
    font-size: 14px;
}

.overview-group-meta {
    position: relative;
    z-index: 1;
}

.overview-group-meta span {
    background: rgba(255, 255, 255, 0.84);
    border-color: rgba(217, 223, 211, 0.9);
    backdrop-filter: blur(6px);
}

.overview-welcome-card h1 {
    margin: 0;
    font-size: 30px;
}

.overview-welcome-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.overview-settings-button {
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    border-radius: 16px;
}

.overview-settings-button span {
    display: block;
    font-size: 24px;
    line-height: 1;
}

.overview-settings-modal-card {
    width: min(560px, calc(100vw - 28px));
}

.overview-settings-stack {
    display: grid;
    gap: 14px;
}

.overview-setting-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 20px;
    border-radius: 18px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
}

.overview-setting-copy {
    display: grid;
    gap: 5px;
}

.overview-setting-copy strong {
    font-size: 18px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-setting-copy span,
.overview-settings-note {
    color: var(--av-muted);
}

.theme-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}

.theme-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.theme-switch-track {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 60px;
    height: 34px;
    padding: 4px;
    border-radius: 999px;
    background: rgba(24, 27, 28, 0.14);
    border: 1px solid rgba(24, 27, 28, 0.08);
    transition: background 0.2s ease, border-color 0.2s ease;
}

.theme-switch-thumb {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: #ffffff;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
    transition: transform 0.2s ease;
}

.theme-switch input:checked + .theme-switch-track {
    background: rgba(179, 240, 0, 0.58);
    border-color: rgba(179, 240, 0, 0.34);
}

.theme-switch input:checked + .theme-switch-track .theme-switch-thumb {
    transform: translateX(26px);
}

.overview-gantt-card {
    position: relative;
    padding: 0;
    overflow: hidden;
    border-top: 0;
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.18);
    margin-bottom: 24px;
}

.overview-gantt-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 8px;
    background: var(--av-green);
    z-index: 2;
    pointer-events: none;
}

.overview-gantt-toolbar,
.overview-gantt-nav,
.overview-gantt-shell {
    padding: 22px;
}

.overview-gantt-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    border-bottom: 1px solid rgba(179, 240, 0, 0.24);
}

.overview-gantt-copy {
    display: grid;
    gap: 4px;
}

.overview-gantt-copy h2 {
    margin: 0;
    font-size: 18px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-gantt-copy span,
.overview-gantt-date-pill span,
.overview-message-meta span {
    color: var(--av-muted);
}

.overview-gantt-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 14px;
}

.overview-gantt-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.overview-gantt-filters .form-field {
    min-width: 200px;
    margin: 0;
}

.overview-gantt-nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 14px;
}

.gantt-nav-label-mobile,
.gantt-nav-date-mobile {
    display: none;
}

.gantt-nav-button,
.overview-gantt-date-pill,
.calendar-gantt-week-pill {
    justify-content: center;
}

.overview-gantt-date-pill {
    min-width: 220px;
    padding: 12px 18px;
    border-radius: 14px;
    text-align: center;
    border: 1px solid var(--av-border);
    background: #fff;
    display: grid;
    gap: 4px;
}

.overview-date-jump {
    cursor: pointer;
}

.overview-hidden-date-picker {
    position: absolute;
    left: -9999px;
    opacity: 0;
    pointer-events: none;
}

.overview-gantt-date-pill,
.calendar-gantt-week-pill {
    position: relative;
    overflow: hidden;
    cursor: pointer;
}

.overview-inline-date-picker {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.overview-gantt-date-pill strong {
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-gantt-shell {
    display: grid;
    gap: 16px;
    overflow-x: auto;
}

.overview-gantt-scale,
.overview-gantt-track {
    min-width: 980px;
}

.overview-gantt-scale {
    position: relative;
    height: 34px;
    margin-bottom: 12px;
}

.overview-gantt-scale-marker {
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    font-size: 14px;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
    color: var(--av-muted);
    white-space: nowrap;
}

.overview-gantt-scale-marker.is-end {
    transform: translateX(-100%);
}

.overview-gantt-track {
    position: relative;
    min-height: 86px;
    border-radius: 18px;
    border: 1px solid #d7d7d7;
    background:
        repeating-linear-gradient(
            to right,
            rgba(0, 0, 0, 0.07) 0,
            rgba(0, 0, 0, 0.07) 1px,
            transparent 1px,
            transparent calc(100% / var(--overview-slot-count, 21))
        ),
        linear-gradient(180deg, #f1f1f1 0%, #e4e4e4 100%);
    overflow: hidden;
}

.overview-gantt-empty {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--av-muted);
    font-size: 13px;
}

.overview-gantt-row {
    display: grid;
    gap: 10px;
}

.overview-gantt-row-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.overview-gantt-row-aircraft {
    display: flex;
    align-items: center;
    gap: 12px;
}

.overview-gantt-row-thumb {
    width: 54px;
    height: 54px;
    border-radius: 14px;
    background-size: cover;
    background-position: center;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.overview-gantt-row-heading strong {
    font-size: 20px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-gantt-row-heading span {
    color: var(--av-muted);
    font-size: 13px;
}

.overview-gantt-track-empty {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--av-muted);
    font-size: 13px;
}

.overview-gantt-bar {
    position: absolute;
    top: 14px;
    bottom: 14px;
    min-width: 44px;
    padding: 10px 12px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(179, 240, 0, 0.96), rgba(133, 198, 0, 0.94));
    color: #1a1d1e;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
    display: grid;
    gap: 4px;
    overflow: hidden;
}

.overview-gantt-bar-charging {
    background: linear-gradient(135deg, rgba(35, 172, 226, 0.95), rgba(4, 114, 187, 0.95));
    color: #fff;
}

.overview-gantt-bar-other-member {
    background: linear-gradient(135deg, rgba(246, 199, 206, 0.97), rgba(232, 149, 162, 0.95));
    color: #4b2028;
}

.overview-gantt-bar-voucher {
    background: linear-gradient(135deg, rgba(255, 182, 72, 0.98), rgba(236, 131, 27, 0.95));
    color: #4b2b06;
}

.overview-gantt-bar-closure {
    background: repeating-linear-gradient(
        135deg,
        rgba(74, 83, 89, 0.95),
        rgba(74, 83, 89, 0.95) 12px,
        rgba(54, 60, 66, 0.96) 12px,
        rgba(54, 60, 66, 0.96) 24px
    );
    color: #ffffff;
}

.overview-gantt-bar-charging span {
    color: rgba(255, 255, 255, 0.82);
}

.overview-gantt-bar-other-member span {
    color: rgba(75, 32, 40, 0.78);
}

.overview-gantt-bar-voucher span {
    color: rgba(75, 43, 6, 0.78);
}

.overview-gantt-bar-closure span {
    color: rgba(255, 255, 255, 0.82);
}

.overview-gantt-bar strong,
.overview-gantt-bar span,
.overview-gantt-bar small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.overview-gantt-bar strong {
    font-size: 13px;
}

.overview-gantt-bar span {
    font-size: 11px;
    color: rgba(0, 0, 0, 0.72);
}

.overview-gantt-bar small {
    font-size: 10px;
    color: rgba(0, 0, 0, 0.62);
}

.overview-panel-grid {
    grid-template-columns: 1fr 1.1fr;
    align-items: start;
}

.overview-stack-grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 18px;
    align-items: start;
}

.overview-stack-column {
    display: grid;
    gap: 18px;
    align-content: start;
}

.bookings-search-card {
    margin-bottom: 18px;
}

.bookings-toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.bookings-page-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
}

.bookings-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    text-decoration: none;
    color: #111111;
}

.bookings-icon-button span {
    display: block;
    font-size: 24px;
    line-height: 1;
    color: #111111;
}

.bookings-view-switch {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.bookings-view-switch .ghost-button.is-active {
    background: var(--av-green);
    border-color: rgba(179, 240, 0, 0.32);
}

.bookings-search-form {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 14px;
}

.bookings-search-form .form-field {
    flex: 1;
    min-width: 260px;
    margin: 0;
}

.bookings-search-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.booking-sync-card {
    max-width: 860px;
}

.booking-sync-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
}

.booking-sync-option-card {
    display: grid;
    gap: 12px;
    padding: 18px 20px;
}

.booking-sync-copy {
    margin: 0;
}

.booking-sync-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.booking-sync-field {
    margin: 0;
}

.booking-sync-field input[readonly] {
    cursor: text;
}

.overview-next-booking-hero {
    padding: 18px 20px;
    border-radius: 18px;
    background: var(--av-panel-soft);
    border: 1px solid var(--av-border);
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 16px;
    margin-bottom: 12px;
}

.overview-next-booking-image {
    min-height: 138px;
    border-radius: 18px;
    background-size: cover;
    background-position: center;
}

.overview-next-booking-copy {
    display: grid;
    gap: 8px;
    align-content: start;
}

.overview-next-booking-hero strong {
    font-size: 28px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.overview-next-booking-hero p {
    margin: 0;
    color: var(--av-muted);
}

.overview-booking-list {
    display: grid;
    gap: 10px;
}

.overview-voucher-queue-list {
    display: grid;
    gap: 10px;
}

.overview-voucher-queue-item {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
    text-decoration: none;
    color: inherit;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.overview-voucher-queue-item:hover,
.overview-voucher-queue-item:focus {
    border-color: rgba(179, 240, 0, 0.6);
    box-shadow: 0 18px 30px rgba(32, 37, 34, 0.09);
    transform: translateY(-1px);
}

.overview-voucher-queue-thumb {
    width: 88px;
    height: 68px;
    border-radius: 16px;
    background: #dce3da center/cover no-repeat;
}

.overview-voucher-queue-copy {
    display: grid;
    gap: 4px;
}

.overview-voucher-queue-copy span {
    color: var(--av-muted);
    font-size: 14px;
}

.overview-voucher-queue-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.overview-booking-list-item {
    width: 100%;
    border: 1px solid var(--av-border);
    border-radius: 16px;
    background: #fff;
    display: grid;
    grid-template-columns: 70px 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 10px 12px;
    cursor: pointer;
    text-align: left;
}

.overview-booking-list-item strong {
    display: block;
    margin-bottom: 4px;
}

.overview-booking-list-item span {
    color: var(--av-muted);
}

.overview-booking-list-thumb {
    width: 70px;
    height: 56px;
    border-radius: 14px;
    background-size: cover;
    background-position: center;
}

.overview-quick-message-form {
    display: grid;
    gap: 14px;
    margin-bottom: 18px;
}

.overview-quick-message-form textarea {
    width: 100%;
    border-radius: 16px;
    border: 1px solid var(--av-border);
    padding: 14px 16px;
    min-height: 108px;
    resize: vertical;
    background: #fff;
}

.overview-message-list {
    display: grid;
    gap: 12px;
}

.overview-message-item {
    padding: 16px 18px;
    border-radius: 18px;
    background: var(--av-panel-soft);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.overview-message-image {
    width: 100%;
    margin-top: 12px;
    border-radius: 16px;
    max-height: 280px;
    object-fit: cover;
}

.overview-message-item p {
    margin: 10px 0 0;
    color: var(--av-text);
    line-height: 1.55;
}

.overview-message-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px 14px;
}

.overview-message-meta strong {
    font-size: 14px;
}

.overview-weather-card,
.overview-map-card {
    align-content: start;
}

.weather-toggle-row {
    display: flex;
    gap: 10px;
    margin-bottom: 16px;
}

.weather-toggle.is-active {
    background: var(--av-green);
    border-color: rgba(179, 240, 0, 0.28);
}

.weather-view {
    display: none;
    gap: 14px;
}

.weather-view.is-active {
    display: grid;
}

.weather-block {
    border: 1px solid var(--av-border);
    border-radius: 18px;
    padding: 16px 18px;
    background: var(--av-panel-soft);
}

.weather-block pre {
    margin: 10px 0 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: 'roboto-light', Arial, sans-serif;
    line-height: 1.55;
}

.weather-list {
    display: grid;
    gap: 8px;
    margin: 10px 0 0;
}

.weather-list div {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 12px;
}

.weather-list dt {
    color: var(--av-muted);
}

.weather-list dd {
    margin: 0;
}

.weather-clouds {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.weather-clouds span,
.taf-period {
    border-radius: 14px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.06);
    padding: 10px 12px;
}

.taf-period-list {
    display: grid;
    gap: 10px;
    margin-top: 10px;
}

.taf-period strong,
.taf-period span,
.taf-period p {
    display: block;
}

.taf-period span,
.taf-period p,
.landaway-route-item span {
    color: var(--av-muted);
}

.taf-period p {
    margin: 6px 0 0;
}

.overview-landaway-map {
    position: relative;
    z-index: 1;
    height: 340px;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: linear-gradient(180deg, #eef2e8 0%, #e1e7dc 100%);
}

.overview-landaway-map-shell {
    position: relative;
}

.overview-landaway-map-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px;
    text-align: center;
}

.overview-landaway-map .leaflet-container,
.overview-landaway-map .leaflet-pane,
.overview-landaway-map .leaflet-top,
.overview-landaway-map .leaflet-bottom,
.overview-landaway-map .leaflet-control {
    z-index: 1;
}

.overview-landaway-map.is-fallback {
    display: flex;
    align-items: stretch;
    justify-content: stretch;
}

.overview-route-fallback {
    width: 100%;
    height: 100%;
    display: block;
}

.overview-route-fallback-label,
.overview-route-fallback-caption {
    font-family: 'roboto-light', Arial, sans-serif;
    fill: #202425;
}

.overview-route-fallback-label {
    font-size: 12px;
    font-weight: bold;
}

.overview-route-fallback-caption {
    font-size: 11px;
}

.overview-landaway-route-overlay {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 3;
    display: grid;
    gap: 8px;
    max-width: min(280px, calc(100% - 28px));
}

.overview-landaway-route-card {
    display: grid;
    gap: 2px;
    padding: 10px 12px;
    border: 1px solid rgba(24, 27, 28, 0.1);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.92);
    color: #181b1c;
    text-align: left;
    box-shadow: 0 14px 26px rgba(24, 27, 28, 0.12);
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.overview-landaway-route-card strong,
.overview-landaway-route-card span {
    color: inherit;
}

.overview-landaway-route-card strong {
    font-size: 0.86rem;
}

.overview-landaway-route-card span {
    font-size: 0.76rem;
    opacity: 0.72;
}

.overview-landaway-route-card:hover,
.overview-landaway-route-card:focus {
    border-color: rgba(179, 240, 0, 0.82);
    box-shadow: 0 16px 30px rgba(24, 27, 28, 0.16);
    outline: none;
    transform: translateY(-1px);
}

.overview-landaway-route-card.is-unmappable {
    opacity: 0.72;
}

.landaway-route-list {
    display: grid;
    gap: 10px;
    margin-top: 14px;
}

.landaway-route-item {
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border-radius: 16px;
    background: var(--av-panel-soft);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.modal-shell {
    position: fixed;
    inset: 0;
    background: rgba(24, 27, 28, 0.72);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 2000;
}

.modal-shell.is-visible {
    display: flex;
}

.modal-card {
    position: relative;
    z-index: 2001;
    width: min(640px, 100%);
    background: #fff;
    border-radius: 24px;
    box-shadow: 0 30px 70px rgba(0, 0, 0, 0.28);
    padding: 22px;
    max-height: 86vh;
    overflow-y: auto;
}

.date-jump-modal-card {
    width: min(460px, 100%);
}

.date-jump-copy {
    margin: 0;
    color: var(--av-muted);
    line-height: 1.5;
}

.booking-modal-hero {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 16px;
    align-items: start;
}

.booking-modal-thumb {
    min-height: 140px;
    border-radius: 18px;
    background-size: cover;
    background-position: center;
}

.booking-modal-hero strong {
    display: block;
    margin-bottom: 6px;
}

.booking-modal-hero span,
.booking-modal-hero p {
    color: var(--av-muted);
}

.page-intro-inline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.overview-announcement-actions,
.bookings-toolbar-actions,
.bookings-page-actions,
.bookings-view-switch,
.bookings-search-actions,
.booking-action-buttons,
.messages-page-actions,
.form-actions,
.modal-actions,
.invoice-accounting-header-actions,
.invoice-inline-actions,
.member-toolbar-actions,
.member-page-actions,
.member-filter-switch,
.invoice-filter-switch,
.subscription-history-actions,
.voucher-list-actions,
.charging-card-action-icons,
.checkout-aircraft-filters {
    gap: var(--av-action-gap);
}

.messages-page-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.messages-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    color: #111111;
}

.messages-icon-button span {
    display: block;
    font-size: 24px;
    line-height: 1;
    color: #111111;
}

.messages-summary-card {
    margin-bottom: 18px;
}

.messages-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.messages-summary-stat {
    padding: 18px 20px;
    border-radius: 18px;
    background: var(--av-panel-soft);
    border: 1px solid rgba(0, 0, 0, 0.06);
    display: grid;
    gap: 4px;
}

.messages-summary-stat strong {
    font-size: 28px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.messages-summary-stat span {
    color: var(--av-muted);
}

.messages-thread-stack {
    display: grid;
    gap: 16px;
}

.message-thread-card {
    display: grid;
    gap: 18px;
}

.message-thread-card.is-unread-thread {
    border-color: rgba(215, 38, 61, 0.2);
    box-shadow: 0 18px 36px rgba(24, 27, 28, 0.08);
}

.message-thread-header {
    margin-bottom: 0;
}

.message-thread-heading-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 6px;
}

.status-pill-group {
    background: rgba(179, 240, 0, 0.16);
    color: #364700;
}

.message-unread-pill {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(215, 38, 61, 0.12);
    color: #b11629;
    font-size: 12px;
    font-weight: 600;
}

.message-bubble-list {
    display: grid;
    gap: 12px;
}

.message-bubble {
    padding: 16px 18px;
    border-radius: 20px;
    border: 1px solid rgba(0, 0, 0, 0.06);
    background: var(--av-panel-soft);
    display: grid;
    gap: 10px;
}

.message-bubble.is-mine {
    background: rgba(179, 240, 0, 0.12);
    border-color: rgba(179, 240, 0, 0.22);
}

.message-bubble.is-unread {
    background: rgba(215, 38, 61, 0.06);
    border-color: rgba(215, 38, 61, 0.16);
}

.message-bubble-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.message-bubble-meta span {
    color: var(--av-muted);
    font-size: 12px;
}

.message-booking-link {
    display: inline-flex;
    align-items: center;
    padding: 6px 11px;
    border-radius: 999px;
    background: rgba(35, 172, 226, 0.12);
    color: #0d5d7a;
    font-size: 12px;
    font-weight: 600;
    width: fit-content;
}

.message-bubble-image {
    width: min(20%, 180px);
    min-width: 120px;
    max-height: 320px;
    object-fit: cover;
    border-radius: 16px;
    justify-self: start;
}

.message-bubble p {
    margin: 0;
    line-height: 1.6;
}

.message-composer-modal {
    width: min(760px, calc(100vw - 32px));
}

.messages-compose-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.messages-audience-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.messages-audience-option {
    align-items: flex-start;
}

.messages-audience-option span {
    display: grid;
    gap: 2px;
}

.messages-audience-option small {
    color: var(--av-muted);
    font-size: 12px;
}

.system-log-list {
    display: grid;
    gap: 12px;
}

.system-log-item {
    padding: 16px 18px;
    border-radius: 18px;
    background: var(--av-panel-soft);
    border: 1px solid rgba(0, 0, 0, 0.06);
    display: grid;
    gap: 8px;
}

.system-log-item-head,
.system-log-item-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.system-log-item p {
    margin: 0;
}

.booking-manage-card {
    width: min(1080px, 100%);
}

.booking-modal-header {
    margin-bottom: 18px;
}

.booking-manage-grid {
    display: grid;
    grid-template-columns: minmax(260px, 0.9fr) minmax(360px, 1.2fr);
    gap: 18px;
    margin-top: 18px;
}

.booking-manage-section {
    padding: 20px;
}

.booking-empty-tight {
    margin: 0;
}

.booking-log-list {
    display: grid;
    gap: 12px;
}

.booking-log-card {
    border: 1px solid var(--av-border);
    border-radius: 18px;
    padding: 14px 16px;
    background: rgba(246, 247, 248, 0.8);
}

.booking-log-card-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: baseline;
    margin-bottom: 8px;
}

.booking-log-card-head span {
    color: var(--av-muted);
    font-size: 13px;
}

.booking-log-meta {
    margin-bottom: 0;
}

.booking-log-notes {
    margin: 10px 0 0;
    color: var(--av-muted);
}

.booking-file-input-copy,
.booking-log-hobbs-warning {
    display: block;
    margin-top: 8px;
}

.booking-log-form input.is-warning {
    border-color: #c84a44;
    background: rgba(200, 74, 68, 0.08);
    color: #8f1f1a;
}

.flight-log-image-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 400px));
    gap: 10px;
    margin-top: 12px;
}

.flight-log-image-link {
    display: block;
    width: 100%;
    max-width: 400px;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(27, 30, 31, 0.12);
    background: rgba(255, 255, 255, 0.9);
}

.flight-log-image-thumb {
    display: block;
    width: 100%;
    max-width: 400px;
    height: auto;
    aspect-ratio: auto;
    object-fit: cover;
}

.booking-voucher-banner {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(179, 240, 0, 0.12);
    border: 1px solid rgba(179, 240, 0, 0.36);
}

.booking-voucher-banner strong {
    display: block;
    margin-bottom: 4px;
}

.booking-voucher-banner span,
.booking-voucher-banner p {
    color: #56631c;
}

.booking-voucher-banner p {
    margin: 8px 0 0;
}

.booking-log-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.booking-conditional-block {
    display: none;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid rgba(178, 178, 178, 0.22);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.72);
}

.booking-conditional-block.is-active {
    display: grid;
}

.booking-conditional-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: baseline;
    flex-wrap: wrap;
}

.booking-manage-actions {
    margin-top: 10px;
}

.modal-actions {
    margin-top: 20px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
}

.stats-grid,
.panel-grid,
.card-grid,
.member-grid {
    display: grid;
    gap: 18px;
}

.stats-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    margin-bottom: 22px;
}

.panel-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.card-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.member-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.stat-card,
.panel-card,
.aircraft-card,
.member-card,
.auth-card,
.setup-card {
    background: var(--av-panel);
    border-radius: 24px;
    box-shadow: var(--av-shadow);
    border: 1px solid rgba(0, 0, 0, 0.04);
}

.stat-card {
    padding: 20px;
}

.stat-card span {
    display: block;
    color: var(--av-muted);
    font-size: 13px;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.stat-card strong {
    font-size: 34px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.panel-card,
.auth-card,
.setup-card {
    padding: 22px;
}

.voucher-portal-card {
    display: grid;
    gap: 18px;
    width: 100%;
    max-width: none;
    margin: 0;
}

.voucher-portal-card > * {
    width: 100%;
    max-width: 100%;
}

.voucher-portal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    text-align: left;
}

.voucher-portal-header > div:first-child {
    flex: 1 1 auto;
    min-width: 0;
}

.voucher-portal-provisional {
    padding: 14px 18px;
    border-radius: 18px;
    background: rgba(179, 240, 0, 0.14);
    border: 1px solid rgba(179, 240, 0, 0.34);
    color: #334112;
    line-height: 1.6;
}

.voucher-portal-panel {
    padding: 18px 20px;
    border-radius: 20px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
    display: grid;
    gap: 12px;
    width: 100%;
}

.voucher-portal-main-panel {
    gap: 16px;
}

.voucher-portal-section-title {
    color: var(--av-text);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 12px;
    font-weight: 700;
}

.voucher-portal-form-panel p {
    margin: 0;
    color: var(--av-muted);
}

.voucher-portal-detail-list {
    display: grid;
    gap: 12px;
}

.voucher-portal-detail-list div {
    display: grid;
    gap: 4px;
}

.voucher-portal-detail-list strong,
.voucher-portal-contact-card strong,
.voucher-portal-request-card strong {
    color: var(--av-text);
    font-size: 15px;
}

.voucher-portal-detail-list span,
.voucher-portal-contact-card span,
.voucher-portal-request-card span {
    color: var(--av-muted);
    line-height: 1.6;
}

.voucher-portal-contact-card {
    display: grid;
    gap: 6px;
    justify-items: start;
    align-items: start;
}

.voucher-portal-request-card {
    padding: 18px 20px;
    border-radius: 20px;
    border: 1px solid rgba(255, 182, 72, 0.36);
    background: rgba(255, 182, 72, 0.1);
    display: grid;
    gap: 8px;
    width: 100%;
}

.voucher-portal-payment-card .modal-actions {
    margin-top: 8px;
}

.voucher-portal-request-card p {
    margin: 0;
    color: var(--av-text);
    line-height: 1.6;
}

.voucher-portal-divider {
    height: 1px;
    background: var(--av-border);
}

.panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.panel-header h2 {
    margin: 0;
    font-size: 20px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.panel-header a {
    color: var(--av-muted);
    font-size: 14px;
}

.list-row,
.booking-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 0;
    border-top: 1px solid var(--av-border);
}

.list-row:first-of-type,
.booking-row:first-of-type {
    border-top: 0;
    padding-top: 0;
}

.list-row strong,
.booking-copy strong {
    display: block;
}

.list-row span,
.booking-copy span,
.empty-state {
    color: var(--av-muted);
}

.booking-row {
    align-items: center;
}

.booking-row-card {
    align-items: center;
}

.booking-thumb {
    width: 60px;
    height: 60px;
    border-radius: 14px;
    background-size: cover;
    background-position: center;
    flex-shrink: 0;
}

.booking-copy {
    flex: 1;
}

.booking-copy strong {
    margin-bottom: 2px;
}

.booking-row-voucher {
    border-color: rgba(236, 131, 27, 0.24);
    background: linear-gradient(180deg, rgba(255, 176, 69, 0.06), rgba(255, 255, 255, 0.95));
}

.booking-voucher-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(255, 182, 72, 0.16);
    color: #8d4e08;
    font-size: 12px;
    font-weight: 700;
}

.booking-copy span {
    line-height: 1.35;
}

.booking-meta {
    white-space: nowrap;
    color: var(--av-muted);
}

.booking-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px 12px;
}

.bookings-restriction-copy {
    margin: 0 0 16px;
}

.booking-action-buttons {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.booking-inline-note {
    display: inline-block;
    max-width: 220px;
    text-align: right;
}

.aircraft-card {
    overflow: hidden;
}

.aircraft-image {
    height: 180px;
    background-size: cover;
    background-position: center;
}

.aircraft-copy {
    padding: 20px;
}

.aircraft-copy h2 {
    margin: 0 0 8px;
    font-size: 24px;
}

.chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0;
}

.chip,
.status-pill {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(179, 240, 0, 0.12);
    color: #56631c;
    font-size: 12px;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.status-pill-paid {
    background: rgba(179, 240, 0, 0.14);
    color: #56631c;
}

.status-pill-open {
    background: rgba(35, 172, 226, 0.12);
    color: #0e6a8b;
}

.status-pill-disputed {
    background: rgba(232, 149, 162, 0.16);
    color: #8c3344;
}

.status-pill-refunded {
    background: rgba(111, 145, 172, 0.14);
    color: #31506a;
}

.status-pill-available,
.status-pill-online,
.status-pill-active {
    background: rgba(179, 240, 0, 0.14);
    color: #56631c;
}

.status-pill-unavailable,
.status-pill-completed {
    background: rgba(24, 27, 28, 0.08);
    color: #4a5153;
}

.status-pill-void {
    background: rgba(169, 46, 46, 0.12);
    color: var(--av-danger);
}

.meta-list,
.profile-grid {
    display: grid;
    gap: 12px;
}

.meta-list div,
.profile-grid div {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--av-border);
}

.meta-list dt,
.profile-grid dt {
    color: var(--av-muted);
}

.calendar-toolbar {
    margin-bottom: 18px;
}

.filter-form {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: end;
}

.filter-form label,
.auth-form label {
    display: block;
    margin-bottom: 8px;
    color: var(--av-muted);
}

.filter-form input,
.filter-form select,
.auth-form input,
.auth-form select,
.bookings-search-form input,
.invoice-report-form input,
.invoice-accounting-modal-search input,
.stack-form input,
.stack-form select,
.stack-form textarea,
.voucher-assign-form input,
.voucher-assign-form select {
    width: 100%;
    min-width: 220px;
    border-radius: 14px;
    border: 1px solid var(--av-border);
    padding: 12px 14px;
    background: #fff;
}

.filter-form button,
.auth-form button,
.primary-button {
    border: 0;
    border-radius: 14px;
    background: var(--av-green);
    color: #1a1d1e;
    padding: 12px 18px;
    cursor: pointer;
    font-weight: bold;
}

.ghost-button {
    border: 1px solid var(--av-border);
    border-radius: 14px;
    background: #fff;
    color: var(--av-text);
    padding: 10px 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    cursor: pointer;
    font-weight: bold;
}

.primary-button:disabled,
.ghost-button:disabled {
    cursor: not-allowed;
    opacity: 0.52;
}

.danger-button {
    color: var(--av-danger);
}

.stack-form {
    display: grid;
    gap: 16px;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.form-field {
    display: grid;
    gap: 8px;
}

.form-field span,
.subtle-copy {
    color: var(--av-muted);
}

.form-field-full {
    grid-column: 1 / -1;
}

.stack-form textarea {
    min-height: 96px;
    resize: vertical;
}

.form-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.checkbox-grid {
    display: grid;
    gap: 12px;
}

.checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
}

.checkbox-row input {
    width: 18px;
    height: 18px;
    min-width: 18px;
    margin-top: 2px;
}

.checkbox-row span {
    color: var(--av-text);
}

.inline-action-form {
    margin: 0;
}

.table-action-cell {
    min-width: 260px;
}

.voucher-assign-form {
    display: grid;
    gap: 10px;
}

.voucher-assign-form input,
.voucher-assign-form select {
    min-width: 0;
    padding: 10px 12px;
}

.voucher-assign-form .primary-button,
.inline-action-form .ghost-button {
    width: 100%;
}

.calendar-shell {
    overflow: hidden;
}

.calendar-scroll {
    overflow-x: auto;
}

.calendar-table,
.data-table {
    width: 100%;
    border-collapse: collapse;
}

.calendar-table th,
.calendar-table td,
.data-table th,
.data-table td {
    border-top: 1px solid var(--av-border);
    padding: 14px 12px;
    vertical-align: top;
    text-align: left;
}

.calendar-table thead th,
.data-table thead th {
    border-top: 0;
    font-size: 12px;
    color: var(--av-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.calendar-slot-label {
    white-space: nowrap;
    font-weight: bold;
    color: var(--av-muted);
}

.calendar-empty {
    color: var(--av-muted);
    font-size: 13px;
}

.calendar-entry {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 8px 10px;
    border-radius: 12px;
    margin-bottom: 6px;
    background: rgba(179, 240, 0, 0.12);
}

.calendar-entry span {
    color: var(--av-muted);
    font-size: 12px;
}

.calendar-entry-charging {
    background: rgba(23, 40, 83, 0.1);
}

.calendar-gantt-card {
    padding: 0;
    overflow: hidden;
    border-top: 8px solid var(--av-green);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.18);
}

.calendar-aircraft-panel {
    margin-bottom: 18px;
}

.calendar-aircraft-select-form {
    display: none;
    margin-bottom: 14px;
}

.calendar-aircraft-select-form .form-field {
    margin: 0;
}

.calendar-aircraft-picker {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 14px;
}

.calendar-aircraft-tile {
    padding: 12px;
    border-radius: 18px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
    display: grid;
    gap: 8px;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.calendar-aircraft-tile:hover,
.calendar-aircraft-tile.is-active {
    transform: translateY(-2px);
    border-color: rgba(179, 240, 0, 0.42);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.1);
}

.calendar-aircraft-tile.is-active {
    background: linear-gradient(180deg, rgba(179, 240, 0, 0.26), rgba(255, 255, 255, 0.98));
}

.calendar-aircraft-tile-image {
    height: 76px;
    border-radius: 16px;
    background-size: cover;
    background-position: center;
}

.calendar-aircraft-tile strong {
    font-size: 18px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.calendar-aircraft-tile span {
    color: var(--av-muted);
    font-size: 13px;
}

.calendar-gantt-toolbar,
.calendar-gantt-weekbar,
.calendar-gantt-shell,
.calendar-gantt-empty {
    padding: 22px;
}

.calendar-gantt-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 18px;
    border-bottom: 1px solid rgba(179, 240, 0, 0.3);
}

.calendar-gantt-copy {
    display: grid;
    gap: 4px;
}

.calendar-gantt-copy h2 {
    margin: 0;
    font-size: 22px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.calendar-gantt-copy span {
    color: var(--av-muted);
}

.calendar-gantt-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 14px;
    flex: 1;
}

.calendar-gantt-filters .form-field {
    min-width: 220px;
    margin: 0;
}

.calendar-gantt-aircraft-card {
    min-width: 260px;
    padding: 16px 18px;
    border-radius: 18px;
    background: var(--av-panel-soft);
    border: 1px solid var(--av-border);
    display: grid;
    grid-template-columns: 92px 1fr;
    gap: 14px;
    align-items: center;
}

.calendar-gantt-aircraft-card-leading {
    margin-right: auto;
}

.calendar-gantt-aircraft-card strong {
    font-size: 26px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.calendar-gantt-aircraft-card span {
    color: var(--av-muted);
}

.calendar-gantt-aircraft-thumb {
    min-height: 74px;
    border-radius: 16px;
    background-size: cover;
    background-position: center;
}

.calendar-gantt-weekbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 14px;
}

.calendar-gantt-week-pill {
    min-width: 220px;
    padding: 12px 18px;
    border-radius: 14px;
    text-align: center;
    border: 1px solid var(--av-border);
    background: #fff;
    display: grid;
    gap: 4px;
}

.calendar-gantt-week-pill strong {
    font-family: 'roboto-thin', Arial, sans-serif;
}

.gantt-nav-copy {
    color: var(--av-muted);
}

.calendar-week-jump {
    cursor: pointer;
}

.calendar-selection-form {
    display: grid;
    gap: 18px;
    padding: 0 22px 22px;
}

.calendar-selection-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.calendar-selection-toolbar.has-alerts {
    margin-bottom: 10px;
}

.calendar-selection-copy {
    display: grid;
    gap: 4px;
}

.calendar-selection-alert-stack {
    display: grid;
    gap: 8px;
    margin-top: 4px;
    margin-bottom: 8px;
}

.calendar-selection-copy span {
    color: var(--av-muted);
}

.calendar-selection-rule {
    font-size: 12px;
}

.calendar-toolbar-alert {
    align-self: center;
}

.calendar-selection-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.calendar-selection-count-box {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(24, 27, 28, 0.12);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.calendar-selection-count-box strong {
    font-size: 20px;
    font-family: 'roboto-thin', Arial, sans-serif;
    line-height: 1;
}

.calendar-gantt-shell {
    display: grid;
    gap: 16px;
    overflow-x: auto;
}

.calendar-gantt-scale,
.calendar-gantt-track {
    min-width: 980px;
}

.calendar-gantt-scale {
    position: relative;
    height: 34px;
    margin-left: 2px;
}

.calendar-gantt-scale-marker {
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    font-size: 14px;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
    color: var(--av-muted);
    white-space: nowrap;
}

.calendar-gantt-scale-marker.is-end {
    transform: translateX(-100%);
}

.mobile-gantt-scale-stick {
    display: none;
}

.mobile-gantt-scale-stick.is-visible {
    display: block;
}

.mobile-gantt-scale-stick .overview-gantt-scale,
.mobile-gantt-scale-stick .calendar-gantt-scale {
    margin: 0;
}

.calendar-gantt-row {
    display: grid;
    gap: 10px;
}

.calendar-gantt-row-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.calendar-gantt-row-heading strong {
    font-size: 20px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.calendar-gantt-row-heading span {
    color: var(--av-muted);
    font-size: 13px;
}

.calendar-gantt-track {
    position: relative;
    min-height: 74px;
    border-radius: 18px;
    border: 1px solid #d7d7d7;
    background:
        repeating-linear-gradient(
            to right,
            rgba(0, 0, 0, 0.07) 0,
            rgba(0, 0, 0, 0.07) 1px,
            transparent 1px,
            transparent calc(100% / var(--calendar-slot-count, 21))
        ),
        linear-gradient(180deg, #f1f1f1 0%, #e4e4e4 100%);
    overflow: visible;
}

.calendar-gantt-track-interactive {
    min-height: 92px;
}

.calendar-slot-grid {
    position: absolute;
    inset: 0;
    z-index: 6;
}

.calendar-slot-button {
    position: absolute;
    top: 10px;
    bottom: 10px;
    padding: 0;
    border: 0;
    border-right: 1px solid rgba(0, 0, 0, 0.06);
    background: transparent;
    cursor: pointer;
    transition: background 0.15s ease, box-shadow 0.15s ease;
    z-index: 6;
    appearance: none;
    -webkit-appearance: none;
    touch-action: manipulation;
}

.calendar-slot-button:hover:not(:disabled) {
    background: rgba(179, 240, 0, 0.16);
}

.calendar-slot-button.is-selected {
    background: rgba(179, 240, 0, 0.5);
    box-shadow: inset 0 0 0 2px rgba(24, 27, 28, 0.18);
}

.calendar-slot-button.is-occupied {
    cursor: not-allowed;
    border-right-color: transparent;
    pointer-events: none;
}

.calendar-slot-button.is-charging {
    cursor: not-allowed;
    pointer-events: none;
}

.calendar-slot-button.is-past-locked {
    cursor: not-allowed;
    pointer-events: none;
    background: rgba(24, 27, 28, 0.08);
}

.calendar-slot-button.is-other-member {
    background: rgba(232, 149, 162, 0.14);
}

.calendar-slot-button.is-voucher {
    background: rgba(255, 182, 72, 0.18);
}

.calendar-gantt-track-empty {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--av-muted);
    font-size: 13px;
    pointer-events: none;
    z-index: 4;
}

.calendar-gantt-bar {
    position: absolute;
    top: 12px;
    bottom: 12px;
    min-width: 40px;
    padding: 8px 10px 8px 20px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(179, 240, 0, 0.96), rgba(133, 198, 0, 0.94));
    color: #1a1d1e;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
    display: grid;
    gap: 3px;
    overflow: hidden;
    z-index: 4;
    pointer-events: none;
}

.calendar-gantt-bar.is-editable {
    pointer-events: auto;
    cursor: grab;
    z-index: 8;
    overflow: hidden;
    transition: box-shadow 0.16s ease, transform 0.16s ease, opacity 0.16s ease;
}

.calendar-gantt-bar.is-editable::before,
.calendar-gantt-bar.is-editable::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 10px;
    background: rgba(68, 72, 74, 0.96);
    opacity: 0;
    transition: opacity 0.16s ease;
    z-index: 10;
    pointer-events: none;
}

.calendar-gantt-bar.is-editable::before {
    left: 0;
}

.calendar-gantt-bar.is-editable::after {
    right: 0;
}

.calendar-gantt-bar.is-editable:hover {
    box-shadow:
        0 0 0 2px rgba(24, 27, 28, 0.18),
        0 14px 24px rgba(0, 0, 0, 0.2);
}

.calendar-gantt-bar.is-editable.is-dragging {
    cursor: grabbing;
    z-index: 12;
    box-shadow:
        0 0 0 2px rgba(24, 27, 28, 0.22),
        0 18px 28px rgba(0, 0, 0, 0.24);
}

.calendar-gantt-bar.is-editable.is-drag-invalid {
    opacity: 0.72;
}

.calendar-gantt-bar.is-editable:hover::before,
.calendar-gantt-bar.is-editable:hover::after,
.calendar-gantt-bar.is-editable.is-dragging::before,
.calendar-gantt-bar.is-editable.is-dragging::after {
    opacity: 1;
}

.calendar-gantt-bar strong,
.calendar-gantt-bar span,
.calendar-gantt-bar small {
    position: relative;
    z-index: 2;
}

.calendar-gantt-bar-handle {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 18px;
    display: block;
    background: transparent;
    opacity: 1;
    z-index: 11;
    pointer-events: auto;
}

.calendar-gantt-bar-handle.is-start {
    left: -4px;
    cursor: ew-resize;
}

.calendar-gantt-bar-handle.is-end {
    right: -4px;
    cursor: ew-resize;
}

body.calendar-gantt-dragging,
body.calendar-gantt-dragging * {
    user-select: none;
}

.calendar-gantt-bar strong,
.calendar-gantt-bar span,
.calendar-gantt-bar small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.calendar-gantt-bar strong {
    font-size: 13px;
}

.calendar-gantt-bar span {
    font-size: 11px;
    color: rgba(0, 0, 0, 0.7);
}

.calendar-gantt-bar small {
    font-size: 10px;
    color: rgba(0, 0, 0, 0.62);
}

.calendar-gantt-bar-charging {
    background: linear-gradient(135deg, rgba(35, 83, 185, 0.94), rgba(23, 40, 83, 0.94));
    color: #fff;
}

.calendar-gantt-bar-other-member {
    background: linear-gradient(135deg, rgba(246, 199, 206, 0.97), rgba(232, 149, 162, 0.95));
    color: #4b2028;
}

.calendar-gantt-bar-voucher {
    background: linear-gradient(135deg, rgba(255, 182, 72, 0.98), rgba(236, 131, 27, 0.95));
    color: #4b2b06;
}

.calendar-gantt-bar-closure {
    background: repeating-linear-gradient(
        135deg,
        rgba(74, 83, 89, 0.96),
        rgba(74, 83, 89, 0.96) 12px,
        rgba(54, 60, 66, 0.98) 12px,
        rgba(54, 60, 66, 0.98) 24px
    );
    color: #ffffff;
}

.calendar-gantt-bar-charging span {
    color: rgba(255, 255, 255, 0.78);
}

.calendar-gantt-bar-other-member span {
    color: rgba(75, 32, 40, 0.78);
}

.calendar-gantt-bar-voucher span {
    color: rgba(75, 43, 6, 0.78);
}

.calendar-gantt-bar-closure span {
    color: rgba(255, 255, 255, 0.82);
}

.calendar-gantt-bar-reservation {
    background: linear-gradient(135deg, rgba(35, 172, 226, 0.96), rgba(6, 113, 180, 0.94));
    color: #ffffff;
}

.calendar-gantt-bar-reservation span {
    color: rgba(255, 255, 255, 0.78);
}

.calendar-slot-button.is-occupied.is-reservation {
    background: rgba(35, 172, 226, 0.14);
}

.calendar-slot-button.is-occupied.is-closure {
    background: rgba(64, 72, 78, 0.28);
    border-color: rgba(64, 72, 78, 0.34);
}

.charging-hero-grid {
    align-items: stretch;
}

.charging-page-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
}

.charging-header-sync-form {
    margin: 0;
}

.charging-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    color: #111111;
    text-decoration: none;
}

.charging-icon-button span {
    display: block;
    font-size: 24px;
    line-height: 1;
    color: #111111;
}

.charging-load-card,
.charging-map-card,
.charging-live-panel,
.charging-list-panel,
.charging-reservation-card {
    overflow: hidden;
}

.charging-map-card {
    position: relative;
    z-index: 0;
    isolation: isolate;
    display: flex;
    flex-direction: column;
}

.charging-map-header {
    align-items: center;
}

.charging-map-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

.charging-map-close-button {
    display: none;
}

.charging-map-card.is-expanded {
    position: fixed;
    top: var(--charging-map-expanded-top, 24px);
    left: var(--charging-map-expanded-left, 24px);
    width: var(--charging-map-expanded-width, calc(100vw - 48px));
    height: var(--charging-map-expanded-height, calc(100vh - 48px));
    z-index: 90;
    margin: 0;
    box-shadow: 0 28px 70px rgba(24, 27, 28, 0.26);
}

.charging-map-card.is-expanded [data-charging-map-open] {
    display: none;
}

.charging-map-card.is-expanded .charging-map-close-button {
    display: inline-flex;
}

.charging-map-card.is-expanded .charging-map-canvas,
.charging-map-card.is-expanded .charging-map-empty {
    min-height: 0;
    height: 100%;
}

.charging-load-meter {
    display: grid;
    gap: 10px;
    margin-bottom: 16px;
}

.charging-load-meter-bar {
    width: 100%;
    height: 14px;
    border-radius: 999px;
    background: rgba(24, 27, 28, 0.08);
    overflow: hidden;
}

.charging-load-meter-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #b3f000 0%, #7ec700 100%);
}

.charging-load-meter strong {
    font-size: 34px;
    font-family: 'roboto-thin', Arial, sans-serif;
}

.charging-load-meter span {
    color: var(--av-muted);
}

.charging-load-stats {
    gap: 10px;
}

.charging-search-form {
    margin-bottom: 18px;
}

.charging-search-shell {
    position: relative;
    flex: 1;
    min-width: 260px;
}

.charging-search-field {
    margin: 0;
}

.charging-search-suggestions {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    z-index: 14;
    display: grid;
    gap: 4px;
    padding: 8px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 34px rgba(24, 27, 28, 0.12);
    max-height: 260px;
    overflow-y: auto;
}

.charging-search-suggestions[hidden] {
    display: none !important;
}

.charging-search-suggestion {
    width: 100%;
    display: grid;
    gap: 2px;
    padding: 10px 12px;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: var(--av-text);
    text-align: left;
    font: inherit;
    cursor: pointer;
}

.charging-search-suggestion strong {
    font-size: 14px;
    line-height: 1.3;
}

.charging-search-suggestion span {
    color: var(--av-muted);
    font-size: 12px;
    line-height: 1.35;
}

.charging-search-suggestion:hover,
.charging-search-suggestion:focus-visible {
    background: rgba(179, 240, 0, 0.14);
    outline: none;
}

.charging-load-reservations {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(24, 27, 28, 0.08);
    display: grid;
    gap: 12px;
}

.charging-map-canvas,
.charging-map-empty {
    flex: 1 1 auto;
    min-height: 280px;
    height: 100%;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(24, 27, 28, 0.08);
    background: linear-gradient(180deg, #f6f8f3 0%, #edf2e8 100%);
}

.charging-map-canvas {
    position: relative;
    z-index: 0;
    isolation: isolate;
}

body.charging-map-expanded {
    overflow: hidden;
}

.charging-map-canvas .leaflet-map-pane,
.charging-map-canvas .leaflet-tile-pane {
    z-index: 1;
}

.charging-map-canvas .leaflet-overlay-pane {
    z-index: 2;
}

.charging-map-canvas .leaflet-shadow-pane {
    z-index: 3;
}

.charging-map-canvas .leaflet-marker-pane {
    z-index: 4;
}

.charging-map-canvas .leaflet-tooltip-pane {
    z-index: 5;
}

.charging-map-canvas .leaflet-popup-pane,
.charging-map-canvas .leaflet-top,
.charging-map-canvas .leaflet-bottom {
    z-index: 6;
}

.charging-map-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
}

.charging-live-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 14px;
}

.charging-live-card {
    display: grid;
    gap: 14px;
    padding: 18px 20px;
    border-radius: 22px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    background: rgba(255, 255, 255, 0.96);
}

.charging-live-card.is-current-user {
    border-color: rgba(179, 240, 0, 0.42);
    box-shadow: 0 12px 28px rgba(179, 240, 0, 0.18);
}

.charging-live-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
}

.charging-live-head span,
.charging-live-meta,
.charging-card-head p,
.charging-session-history-row span {
    color: var(--av-muted);
}

.charging-live-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.charging-live-meta {
    margin: 0;
    font-size: 13px;
}

.charging-reservation-list {
    display: grid;
    gap: 10px;
}

.charging-reservation-list-inline {
    gap: 12px;
}

.charging-reservation-chip {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    background: rgba(255, 255, 255, 0.94);
}

.charging-list-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}

.charging-list-grid.is-search-results {
    grid-template-columns: repeat(auto-fit, minmax(280px, 360px));
    justify-content: flex-start;
}

.charging-list-card {
    display: grid;
    gap: 14px;
    padding: 20px 22px;
    border-radius: 22px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    background: rgba(255, 255, 255, 0.96);
}

.charging-card-mobile-toggle {
    display: none;
}

.charging-card-body {
    display: grid;
    gap: 14px;
}

.charging-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
}

.charging-card-head h3 {
    margin: 0 0 6px;
}

.charging-card-head p,
.charging-card-meta {
    margin: 0;
}

.charging-card-rate-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.charging-card-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.charging-card-actions .inline-form {
    flex: 1 1 auto;
}

.charging-card-action-icons {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.charging-card-actions .inline-form,
.charging-card-actions .primary-button,
.charging-card-actions .ghost-button {
    width: auto;
}

.charging-card-actions .inline-form .primary-button {
    width: 100%;
}

.charging-card-action-icons .ghost-button {
    width: auto;
}

.charging-card-actions .primary-button:disabled,
.charging-card-actions .ghost-button:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.charging-reservation-notes {
    min-width: 220px;
    padding: 11px 14px;
    border-radius: 14px;
    border: 1px solid var(--av-border);
    background: rgba(255, 255, 255, 0.96);
}

.charging-session-history {
    display: grid;
    gap: 10px;
}

.charging-session-history-row {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    padding: 14px 0;
    border-top: 1px solid var(--av-border);
}

.charging-session-history-row:first-child {
    border-top: 0;
    padding-top: 0;
}

.charging-session-history-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.charging-edit-modal,
.charging-sessions-modal {
    width: min(760px, calc(100vw - 32px));
}

.charging-reservation-modal {
    width: min(1160px, calc(100vw - 32px));
    max-height: calc(100vh - 40px);
    overflow-y: auto;
}

.charging-reservation-modal .calendar-gantt-toolbar {
    position: relative;
    padding-right: 110px;
}

.charging-reservation-modal-close {
    position: absolute;
    top: 0;
    right: 0;
}

.charging-reservation-shell {
    margin-top: 6px;
}

.charging-reservation-row.is-hidden {
    display: none;
}

.vouchers-toolbar-card {
    margin-bottom: 18px;
}

.voucher-gantt-card {
    margin-bottom: 18px;
}

.voucher-gantt-card .overview-gantt-track {
    min-height: 92px;
}

.voucher-gantt-card .overview-gantt-bar {
    top: 12px;
    bottom: 12px;
    padding: 8px 12px 8px 20px;
    gap: 3px;
    align-content: center;
}

.voucher-gantt-card .overview-gantt-bar strong,
.voucher-gantt-card .overview-gantt-bar span,
.voucher-gantt-card .overview-gantt-bar small {
    line-height: 1.15;
}

.voucher-list-grid {
    display: grid;
    gap: 14px;
}

.voucher-page-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.voucher-search-shell {
    position: relative;
    flex: 1;
    min-width: 260px;
}

.voucher-search-field {
    margin: 0;
}

.voucher-search-suggestions {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    z-index: 14;
    display: grid;
    gap: 4px;
    padding: 8px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 34px rgba(24, 27, 28, 0.12);
    max-height: 260px;
    overflow-y: auto;
}

.voucher-search-suggestions[hidden] {
    display: none !important;
}

.voucher-search-suggestion {
    width: 100%;
    display: grid;
    gap: 2px;
    padding: 10px 12px;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: var(--av-text);
    text-align: left;
    font: inherit;
    cursor: pointer;
}

.voucher-search-suggestion strong {
    font-size: 14px;
    line-height: 1.3;
}

.voucher-search-suggestion span {
    color: var(--av-muted);
    font-size: 12px;
    line-height: 1.35;
}

.voucher-search-suggestion:hover,
.voucher-search-suggestion:focus-visible {
    background: rgba(179, 240, 0, 0.14);
    outline: none;
}

.voucher-list-card {
    display: grid;
    grid-template-columns: 76px 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 18px 20px;
    border-radius: 22px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    background: rgba(255, 255, 255, 0.96);
}

.voucher-list-thumb {
    width: 76px;
    height: 76px;
    border-radius: 18px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.voucher-list-copy {
    min-width: 0;
}

.voucher-list-head {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    margin-bottom: 8px;
}

.voucher-inline-meta {
    margin-bottom: 10px;
}

.voucher-request-note {
    margin-top: 12px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255, 182, 72, 0.1);
    border: 1px solid rgba(255, 182, 72, 0.28);
    display: grid;
    gap: 4px;
}

.voucher-request-note strong {
    color: var(--av-text);
    font-size: 13px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.voucher-request-note span {
    color: var(--av-text);
}

.voucher-request-note p {
    margin: 0;
    color: var(--av-muted);
    line-height: 1.6;
}

.voucher-payment-note {
    background: rgba(179, 240, 0, 0.14);
    border-color: rgba(179, 240, 0, 0.3);
}

.voucher-list-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    min-width: 150px;
}

.voucher-list-actions .inline-action-form {
    margin: 0;
}

.voucher-form-checkbox {
    width: 100%;
}

[data-voucher-paid-field][hidden],
[data-voucher-payment-amount-field][hidden] {
    display: none !important;
}

.voucher-list-actions .inline-action-form .ghost-button,
.voucher-list-actions .inline-action-form .primary-button {
    width: auto;
}

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

    .voucher-list-thumb {
        width: 100%;
        height: 160px;
    }

    .voucher-list-actions {
        justify-content: flex-start;
        min-width: 0;
    }
}

.calendar-selection-notes {
    margin-top: -4px;
}

.stack-grid {
    display: grid;
    gap: 16px;
}

.inline-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
    color: var(--av-muted);
    margin-bottom: 16px;
}

.item-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.item-list li {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 0;
    border-top: 1px solid var(--av-border);
}

.invoice-card-actions {
    margin-top: 10px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.invoice-action-icon-button {
    min-width: 48px;
    width: 48px;
    height: 44px;
    padding: 0;
}

.invoice-action-icon-button span {
    display: block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1;
}

.invoice-card-actions-static {
    justify-content: flex-start;
}

.invoice-alert-card {
    margin-bottom: 18px;
}

.invoice-filter-switch {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 14px;
}

.invoice-search-card {
    margin-bottom: 16px;
}

.invoice-stripe-settings-modal {
    width: min(760px, calc(100vw - 32px));
}

.invoice-stripe-settings-stack {
    display: grid;
    gap: 18px;
}

.invoice-stripe-connection-card {
    padding: 18px 20px;
    border-radius: 20px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
    display: grid;
    gap: 12px;
}

.invoice-stripe-settings-meta {
    gap: 8px 16px;
}

.invoice-stripe-settings-note {
    margin: 0;
}

.invoice-filter-switch .ghost-button.is-active {
    background: var(--av-green);
    border-color: rgba(179, 240, 0, 0.32);
}

.invoice-stats-grid .stat-card {
    min-width: 0;
}

.invoice-stats-grid .stat-card strong {
    font-size: clamp(28px, 2.6vw, 34px);
}

.invoice-card {
    display: grid;
    gap: 8px;
    padding: 16px 18px;
}

.invoice-card-member {
    margin: 4px 0 0;
}

.invoice-card .panel-header {
    margin-bottom: 4px;
}

.invoice-card .panel-header h2 {
    font-size: 20px;
}

.invoice-card .inline-meta {
    gap: 8px 16px;
    margin-bottom: 4px;
    font-size: 13px;
}

.invoice-card .item-list li {
    padding: 8px 0;
}

.invoice-note {
    margin: 0;
    font-size: 13px;
    color: var(--av-muted);
}

.invoice-note-disputed {
    color: #8c3344;
}

.invoice-note-refunded {
    color: #31506a;
}

.instructor-fee-panel {
    margin-bottom: 16px;
}

.instructor-fee-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: 16px 0;
}

.instructor-fee-summary-grid-modal {
    margin-top: 0;
}

.instructor-fee-log {
    display: grid;
    gap: 10px;
}

.instructor-fee-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    padding: 14px 0;
    border-top: 1px solid var(--av-border);
}

.instructor-fee-copy,
.instructor-fee-meta {
    display: grid;
    gap: 6px;
}

.instructor-fee-meta {
    justify-items: end;
    text-align: right;
}

.instructor-fee-status-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.instructor-fee-action {
    width: auto;
}

.instructor-fee-action .ghost-button {
    width: auto;
}

.subscription-status-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    align-items: center;
    margin-bottom: 18px;
    color: var(--av-muted);
}

.subscription-actions {
    margin-bottom: 18px;
}

.subscription-history-panel {
    border-top: 1px solid var(--av-border);
    padding-top: 18px;
}

.subscription-history-list {
    display: grid;
    gap: 10px;
}

.subscription-history-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 14px 0;
    border-top: 1px solid var(--av-border);
}

.subscription-history-row:first-child {
    border-top: 0;
    padding-top: 0;
}

.invoice-accounting-card,
.invoice-accounting-list {
    display: grid;
    gap: 16px;
}

.invoice-accounting-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
    margin-top: 22px;
    align-items: start;
}

.invoice-accounting-list-card {
    height: 100%;
    align-content: start;
}

.invoice-accounting-header-actions,
.invoice-inline-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.invoice-accounting-list .inline-action-form .primary-button,
.invoice-accounting-list .inline-action-form .ghost-button {
    width: auto;
}

.invoice-report-form {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    align-items: end;
}

.accounting-stats-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.accounting-stats-grid .stat-card,
.invoice-stats-grid .stat-card,
.instructor-fee-summary-grid .stat-card {
    min-width: 0;
}

.accounting-stats-grid .stat-card strong,
.invoice-stats-grid .stat-card strong,
.instructor-fee-summary-grid .stat-card strong {
    font-size: clamp(24px, 2.1vw, 26px);
    line-height: 1.05;
}

.accounting-row-list {
    display: grid;
    gap: 12px;
}

.accounting-row-card {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding: 16px 18px;
    border: 1px solid var(--av-border);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.78);
}

.accounting-row-copy,
.accounting-row-meta {
    display: grid;
    gap: 6px;
}

.accounting-row-meta {
    align-content: start;
    justify-items: end;
    text-align: right;
    margin-left: auto;
    min-width: max-content;
}

.accounting-row-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    justify-self: end;
    width: 100%;
    margin-top: 4px;
    gap: 8px;
}

.accounting-row-actions .inline-action-form {
    display: inline-flex;
}

.accounting-row-actions .inline-action-form .primary-button,
.accounting-row-actions .inline-action-form .ghost-button,
.accounting-row-actions > .ghost-button {
    width: auto !important;
    white-space: nowrap;
}

.accounting-row-card-instructor-fee .accounting-row-copy {
    min-width: 0;
    flex: 1 1 auto;
}

.accounting-row-card-instructor-fee .accounting-row-actions-inline {
    justify-content: flex-start;
    justify-self: start;
    width: auto;
    margin-top: 8px;
}

.invoice-accounting-preview-note {
    display: block;
}

.invoice-accounting-modal-card {
    width: min(960px, calc(100vw - 32px));
}

.invoice-accounting-modal-search {
    margin-bottom: 6px;
}

.invoice-search-empty-state.is-hidden,
#invoiceSearchEmptyState.is-hidden,
.invoice-search-empty-state[hidden],
#invoiceSearchEmptyState[hidden] {
    display: none !important;
}

@media (max-width: 1460px) {
    .invoice-accounting-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.instructor-fee-select-list {
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
}

.instructor-fee-select-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 14px 16px;
    border: 1px solid var(--av-border);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
}

.instructor-fee-select-row input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;
}

.instructor-fee-select-copy {
    display: grid;
    gap: 6px;
}

.subscription-history-meta {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    text-align: right;
}

.subscription-history-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.invoice-admin-card {
    margin-top: 10px;
}

.invoice-modal-shell {
    z-index: 2200;
}

.invoice-action-modal-card {
    width: min(560px, calc(100vw - 32px));
}

.invoice-modal-copy {
    margin: 0 0 14px;
}

.invoice-refund-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.member-card h3 {
    margin: 0 0 8px;
}

.member-card span {
    display: inline-block;
    margin-bottom: 12px;
    color: var(--av-muted);
}

.member-card p {
    margin: 0 0 6px;
}

.member-toolbar-card {
    margin-bottom: 18px;
}

.member-toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.member-page-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.member-header-button {
    white-space: nowrap;
}

.member-settings-button {
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    justify-content: center;
}

.member-settings-button span {
    display: block;
    font-size: 24px;
    line-height: 1;
}

.member-list-panel-header {
    align-items: flex-start;
}

.member-filter-switch {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.member-filter-switch .ghost-button.is-active {
    background: var(--av-green);
    border-color: rgba(179, 240, 0, 0.32);
}

.member-toolbar-copy {
    margin: 14px 0 0;
}

.member-list {
    display: grid;
    gap: 14px;
}

.member-list-item {
    padding: 18px 20px;
    border-radius: 20px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
}

.member-list-main {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.member-list-avatar {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: rgba(179, 240, 0, 0.18);
    color: #4e5a16;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    letter-spacing: 0.08em;
}

.member-list-copy {
    min-width: 0;
}

.member-list-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 10px;
}

.member-list-head h3 {
    margin: 0 0 8px;
}

.member-chip-row {
    margin: 0;
}

.member-status-pill-disabled {
    background: rgba(169, 46, 46, 0.12);
    color: var(--av-danger);
}

.member-status-pill-locked {
    background: rgba(24, 27, 28, 0.1);
    color: #3f4548;
}

.member-status-pill-self {
    background: rgba(35, 172, 226, 0.12);
    color: #0e6a8b;
}

.member-list-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    color: var(--av-muted);
}

.member-list-meta + .member-list-meta {
    margin-top: 8px;
}

.member-list-meta-finance {
    align-items: center;
}

.member-inline-button {
    padding: 7px 12px;
    border-radius: 999px;
}

.member-list-private {
    margin: 0;
    color: var(--av-muted);
}

.member-admin-modal {
    width: min(760px, 100%);
}

.member-admin-modal-wide {
    width: min(920px, 100%);
}

.member-settings-divider {
    height: 1px;
    margin: 24px 0 22px;
    background: var(--av-border);
}

.member-settings-subheader {
    margin-bottom: 16px;
}

.member-aircraft-approval-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-top: 0;
}

.member-aircraft-approval-row {
    align-items: flex-start;
    padding: 14px 16px;
    border: 1px solid rgba(74, 83, 89, 0.12);
    border-radius: 16px;
    background: rgba(74, 83, 89, 0.04);
}

.member-aircraft-approval-row span {
    display: grid;
    gap: 3px;
}

.member-aircraft-approval-row strong {
    color: var(--av-text);
    font-size: 14px;
}

.member-aircraft-approval-row small {
    color: var(--av-muted);
    font-size: 12px;
    font-weight: 500;
}

.member-modal-empty {
    margin-top: 18px;
}

.member-blackout-list {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.member-blackout-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(74, 83, 89, 0.12);
    background: rgba(74, 83, 89, 0.05);
}

.member-blackout-copy {
    display: grid;
    gap: 4px;
}

.member-blackout-copy strong {
    color: var(--av-text);
}

.member-blackout-copy span {
    color: var(--av-muted);
}

.member-blackout-copy p {
    margin: 4px 0 0;
    color: var(--av-muted);
    line-height: 1.6;
}

.member-admin-card {
    display: grid;
    gap: 10px;
}

.member-self-link {
    justify-self: start;
}

.member-admin-details {
    border-top: 1px solid var(--av-border);
    padding-top: 12px;
}

.member-admin-summary {
    cursor: pointer;
    font-weight: bold;
}

.member-admin-body {
    padding-top: 16px;
}

.member-invite-list {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.member-invite-card {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
}

.member-invite-card strong {
    display: block;
    margin-bottom: 4px;
}

.member-invite-card span,
.member-invite-card p {
    color: var(--av-muted);
}

.member-invite-card p {
    margin: 6px 0 0;
}

.member-invite-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: var(--av-action-gap);
}

.member-invite-actions .inline-action-form {
    margin: 0;
}

.member-invite-actions .ghost-button {
    width: auto;
}

.group-settings-card {
    margin-bottom: 18px;
}

.flash {
    padding: 14px 18px;
    border-radius: 14px;
    margin-bottom: 18px;
}

.flash-error {
    background: rgba(169, 46, 46, 0.12);
    color: var(--av-danger);
}

.flash-success {
    background: rgba(42, 122, 59, 0.12);
    color: var(--av-success);
}

.flash-warning {
    background: rgba(232, 149, 162, 0.18);
    color: #7e3342;
}

.booking-hold-banner {
    margin-bottom: 16px;
}

.auth-body,
.setup-body {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
    background: radial-gradient(circle at top left, rgba(179, 240, 0, 0.28), transparent 32%), #eef2e8;
}

.auth-shell {
    width: min(1080px, 100%);
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 22px;
}

.auth-shell-single {
    width: min(760px, 100%);
    display: block;
}

.auth-brand,
.auth-panel {
    border-radius: 28px;
    padding: 36px;
    box-shadow: var(--av-shadow);
}

.auth-brand {
    background: linear-gradient(145deg, #1b1e1f 0%, #303739 100%);
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: end;
    min-height: 520px;
}

.auth-brand-has-image {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.auth-brand-login {
    padding: 0;
    overflow: hidden;
    background:
        radial-gradient(circle at center, rgba(116, 40, 255, 0.28) 0%, rgba(23, 11, 40, 0.96) 58%, #0d0f11 100%);
}

.auth-brand-login-visual {
    min-height: 520px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    overflow: hidden;
}

.auth-brand-login-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    transform: scale(1.2);
    transform-origin: center center;
}

.auth-shell-register .auth-brand-login {
    min-height: 572px;
    height: auto;
    align-self: start;
}

.auth-shell-register .auth-brand-login-visual {
    min-height: 572px;
    height: 100%;
}

.auth-shell-register .auth-brand-login-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.auth-panel {
    background: rgba(255, 255, 255, 0.93);
}

.auth-panel-single {
    width: 100%;
    padding: 0;
}

.auth-brand-mark {
    width: 52px;
    margin-bottom: 22px;
}

.auth-brand-logo {
    width: 180px;
    margin-bottom: 18px;
}

.auth-brand-copy {
    color: rgba(255, 255, 255, 0.72);
    max-width: 420px;
    line-height: 1.6;
}

.auth-brand-has-image .auth-brand-mark,
.auth-brand-has-image .auth-brand-logo,
.auth-brand-has-image .auth-brand-copy {
    text-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
}

@media (min-width: 901px) {
    .auth-shell-login .auth-brand-login {
        margin-left: calc(-1 * max(0px, (100vw - 1080px) / 2));
        width: calc(100% + max(0px, (100vw - 1080px) / 2));
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    .auth-shell-register {
        --register-hero-height: 572px;
        --register-hero-top-offset: max(32px, calc(50vh - 286px));
        align-self: flex-start;
        margin-top: max(0px, calc(var(--register-hero-top-offset) - 32px));
        margin-bottom: 32px;
    }

    .auth-shell-register .auth-brand-login {
        margin-left: 0;
        position: fixed;
        top: var(--register-hero-top-offset);
        left: 0;
        width: calc((100vw - 86px) * 0.55);
        height: var(--register-hero-height);
        min-height: 572px;
        transform: none;
        z-index: 1;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    .auth-shell-register .auth-brand-login-visual {
        min-height: 572px;
    }

    .auth-shell-register .auth-panel {
        grid-column: 2;
    }
}

@media (min-width: 1144px) {
    .auth-shell-register .auth-brand-login {
        width: calc(50vw + 41.9px);
    }
}

.auth-shell-register {
    align-items: start;
}

.auth-brand-register {
    align-self: start;
    min-height: 260px;
    overflow: hidden;
}

.auth-form {
    display: grid;
    gap: 14px;
    margin-top: 26px;
}

.auth-invite-card {
    margin-top: 18px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
}

.auth-invite-card strong {
    display: block;
    margin-bottom: 6px;
}

.auth-invite-card span,
.auth-invite-card p {
    color: var(--av-muted);
}

.auth-invite-card p {
    margin: 8px 0 0;
}

.auth-invite-card-disabled {
    border-color: rgba(169, 46, 46, 0.18);
    background: rgba(169, 46, 46, 0.06);
}

.auth-secondary-link {
    margin-top: 18px;
}

.auth-secondary-link a {
    color: var(--av-muted);
}

.auth-secondary-action {
    display: grid;
    gap: 10px;
}

.auth-secondary-action span {
    color: var(--av-muted);
}

.auth-secondary-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    border: 1px solid #ffffff;
    background: #111518;
    color: #ffffff !important;
}

.auth-secondary-button:hover {
    background: #1a1f22;
    border-color: #ffffff;
    color: #ffffff !important;
}

.setup-card {
    max-width: 560px;
    text-align: center;
}

.setup-logo {
    width: 52px;
    margin: 0 auto 20px;
}

.setup-details {
    margin-top: 18px;
    color: var(--av-muted);
    line-height: 1.6;
}

.status-pill-online {
    background: rgba(179, 240, 0, 0.14);
    color: #56631c;
}

.status-pill-offline {
    background: rgba(232, 149, 162, 0.16);
    color: #8c3344;
}

.aircraft-admin-intro {
    margin-bottom: 18px;
}

.aircraft-page-intro {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.aircraft-card-header {
    align-items: start;
}

.aircraft-summary-chips {
    margin-top: 8px;
}

.aircraft-meta-list {
    margin-top: 12px;
}

.aircraft-meta-list-expanded {
    margin-top: 14px;
}

.aircraft-more-toggle {
    margin-top: 16px;
    border-top: 1px solid rgba(24, 27, 28, 0.08);
    padding-top: 16px;
}

.aircraft-more-toggle summary {
    list-style: none;
}

.aircraft-more-toggle summary::-webkit-details-marker {
    display: none;
}

.aircraft-more-summary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    border-radius: 999px;
    background: transparent;
    border: 1px solid var(--av-border);
    color: var(--av-text);
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.aircraft-more-summary::before {
    content: 'More';
}

.aircraft-more-toggle[open] .aircraft-more-summary::before {
    content: 'Less';
}

.aircraft-more-summary:hover {
    background: rgba(179, 240, 0, 0.08);
    border-color: rgba(179, 240, 0, 0.45);
}

.aircraft-more-content {
    margin-top: 16px;
}

.aircraft-files-panel,
.aircraft-editor-files-panel {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid rgba(24, 27, 28, 0.08);
}

.aircraft-files-panel-header,
.aircraft-editor-files-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.aircraft-files-panel-header strong,
.aircraft-editor-files-header h3 {
    margin: 0;
}

.aircraft-editor-files-header p {
    margin: 4px 0 0;
    color: var(--av-muted);
}

.aircraft-file-list,
.aircraft-editor-file-list {
    display: grid;
    gap: 10px;
}

.aircraft-file-item,
.aircraft-editor-file-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(24, 27, 28, 0.08);
    background: rgba(255, 255, 255, 0.72);
}

.aircraft-editor-file-item {
    flex-wrap: wrap;
}

.aircraft-file-copy,
.aircraft-editor-file-copy {
    display: grid;
    gap: 2px;
}

.aircraft-file-copy span,
.aircraft-editor-file-copy span {
    color: var(--av-muted);
    font-size: 0.85rem;
}

.aircraft-file-actions,
.aircraft-editor-file-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.aircraft-editor-file-delete {
    margin-left: 4px;
}

.aircraft-files-empty {
    margin: 0;
}

.aircraft-editor-modal {
    width: min(1120px, calc(100vw - 32px));
}

.aircraft-editor-hero {
    margin-bottom: 18px;
}

.aircraft-edit-grid {
    gap: 14px;
}

.aircraft-checkbox-grid {
    margin-top: 18px;
}

.aircraft-editor-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
}

.calendar-selection-rule-alert {
    display: block;
    color: #8c3344;
}

.flight-log-filter-panel {
    margin-bottom: 18px;
}

.flight-log-toolbar-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.flight-log-view-switch {
    margin-bottom: 0;
}

.flight-log-aircraft-picker {
    margin-top: 18px;
}

.flight-log-aircraft-tile {
    min-width: 180px;
}

.flight-log-aircraft-tile .status-pill {
    justify-self: start;
}

.flight-log-aircraft-all {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, #1b1e1f 0%, #303739 100%);
    color: #fff;
    font-size: 20px;
    letter-spacing: 0.12em;
}

.flight-log-card {
    padding: 18px 20px;
}

.flight-log-preview {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    gap: 16px;
    align-items: start;
}

.flight-log-thumb {
    width: 72px;
    height: 72px;
}

.flight-log-copy {
    min-width: 0;
}

.flight-log-preview-meta {
    margin-bottom: 0;
}

.flight-log-preview-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.flight-log-details {
    display: none;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--av-border);
}

.flight-log-details.is-open {
    display: block;
}

.flight-log-detail-list {
    margin-top: 0;
}

.flight-log-detail-list dd {
    overflow-wrap: anywhere;
}

@media (max-width: 900px) {
    .flight-log-preview {
        grid-template-columns: 1fr;
    }

    .flight-log-preview-actions {
        justify-content: flex-start;
    }

    .aircraft-page-intro {
        align-items: stretch;
    }
}

@media (max-width: 1100px) {
    .topbar {
        display: flex;
    }

    .app-shell {
        min-height: 100dvh;
    }

    .sidebar {
        --sidebar-pad-x: 18px;
        --sidebar-pad-y: 18px;
        position: fixed;
        left: 0;
        top: 0;
        z-index: 130;
        width: min(320px, calc(100vw - 40px));
        max-width: 100%;
        height: 100dvh;
        padding: var(--sidebar-pad-y) var(--sidebar-pad-x) 24px;
        transform: translateX(-100%);
        transition: transform 0.25s ease;
        box-shadow: 18px 0 40px rgba(0, 0, 0, 0.28);
    }

    .sidebar-view-button {
        display: none;
    }

    .sidebar.is-open {
        transform: translateX(0);
    }

    .sidebar-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .page-shell {
        min-height: 100dvh;
        margin-left: 0;
        width: 100%;
    }

    .page-content {
        min-height: calc(100dvh - 64px);
        padding: 88px 24px 24px;
    }
}

@media (max-width: 900px) {
    .overview-hero-grid,
    .overview-panel-grid,
    .overview-stack-grid {
        grid-template-columns: 1fr;
    }

    .overview-welcome-card,
    .overview-group-card {
        padding: 14px 16px;
        gap: 8px;
    }

    .overview-group-card {
        min-height: 0;
    }

    .overview-welcome-card h1 {
        font-size: 25px;
    }

    .overview-group-media h2 {
        font-size: 20px;
    }

    .overview-group-media p {
        font-size: 12px;
    }

    .overview-stat-strip,
    .overview-group-meta {
        gap: 6px;
    }

    .overview-stat-pill,
    .overview-group-meta span {
        padding: 6px 9px;
        border-radius: 10px;
    }

    .overview-stat-pill strong {
        font-size: 15px;
        line-height: 1;
    }

    .overview-stat-pill span,
    .overview-group-meta span {
        font-size: 11px;
        line-height: 1.2;
    }

    .booking-manage-grid,
    .overview-next-booking-hero,
    .booking-modal-hero {
        grid-template-columns: 1fr;
    }

    .overview-voucher-queue-item {
        grid-template-columns: 72px 1fr;
    }

    .overview-voucher-queue-thumb {
        width: 72px;
        height: 60px;
    }

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

    .auth-brand {
        display: none;
    }

    .calendar-selection-toolbar {
        align-items: stretch;
    }

    #calendarSelectionWindows {
        display: none;
    }

    .calendar-selection-buttons {
        flex-direction: row;
        align-items: stretch;
        width: 100%;
    }

    .calendar-selection-buttons > * {
        flex: 1 1 0;
        min-width: 0;
    }

    .calendar-selection-count-box {
        padding: 0 10px;
    }

    .calendar-selection-count-box strong {
        font-size: 16px;
    }

    .messages-compose-grid {
        grid-template-columns: 1fr;
    }

    .messages-summary-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
    }

    .messages-summary-stat {
        padding: 14px 12px;
    }

    .messages-summary-stat strong {
        font-size: 22px;
    }

    .messages-summary-stat span {
        font-size: 11px;
        line-height: 1.2;
    }

    .messages-audience-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .auth-body {
        padding: 12px;
    }

    .page-content,
    .auth-brand,
    .auth-panel {
        padding: 20px;
    }

    .page-intro h1,
    .auth-card h1 {
        font-size: 28px;
    }

    .auth-login-prefix {
        font-size: 18px;
    }

    .auth-shell-single {
        width: 100%;
        max-width: 100%;
        margin: 0 auto;
    }

    .auth-panel-single {
        padding: 0;
    }

    .voucher-portal-card {
        width: 100%;
        min-width: 0;
        gap: 14px;
        padding: 18px 16px;
    }

    .voucher-portal-card > * {
        min-width: 0;
    }

    .voucher-portal-provisional,
    .voucher-portal-panel,
    .voucher-portal-request-card {
        width: 100%;
        min-width: 0;
        padding: 14px 16px;
    }

    .form-field,
    .filter-form,
    .auth-form,
    .stack-form,
    .voucher-assign-form,
    .booking-log-grid {
        width: 100%;
        min-width: 0;
    }

    .overview-welcome-card,
    .overview-group-card {
        padding: 12px 14px;
        gap: 6px;
    }

    .overview-welcome-card h1 {
        font-size: 22px;
    }

    .overview-group-media h2 {
        font-size: 18px;
    }

    .overview-group-media p {
        font-size: 11px;
        line-height: 1.35;
    }

    .overview-stat-strip,
    .overview-group-meta {
        gap: 5px;
    }

    .overview-stat-pill,
    .overview-group-meta span {
        padding: 5px 8px;
        border-radius: 9px;
    }

    .overview-stat-pill strong {
        font-size: 13px;
    }

    .overview-stat-pill span,
    .overview-group-meta span {
        font-size: 10px;
        line-height: 1.15;
    }

    .page-intro-inline,
    .messages-page-actions,
    .message-thread-header,
    .message-bubble-meta,
    .system-log-item-head,
    .system-log-item-meta {
        align-items: stretch;
    }

    .member-page-actions,
    .member-toolbar-actions {
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        flex-wrap: wrap;
    }

    .member-list-panel-header {
        align-items: center;
    }

    .message-bubble-image {
        width: min(42%, 180px);
        min-width: 0;
    }

    .vouchers-toolbar-card .panel-header {
        flex-wrap: wrap;
        align-items: center;
    }

    .vouchers-toolbar-card .bookings-view-switch {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        margin-bottom: 12px;
    }

    .vouchers-toolbar-card .bookings-view-switch .ghost-button {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    .filter-form {
        flex-direction: column;
        align-items: stretch;
    }

    .overview-gantt-toolbar,
    .overview-gantt-nav {
        align-items: stretch;
    }

    .overview-gantt-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .overview-gantt-filters .form-field,
    .overview-gantt-date-pill {
        min-width: 0;
        width: 100%;
    }

    .overview-gantt-nav,
    .calendar-gantt-weekbar {
        display: grid;
        grid-template-columns: 72px minmax(0, 1fr) 72px;
        gap: 8px;
        align-items: stretch;
    }

    .gantt-nav-button,
    .overview-gantt-date-pill,
    .calendar-gantt-week-pill {
        min-width: 0;
        width: 100%;
        height: 52px;
        padding: 8px 10px;
        border-radius: 12px;
    }

    .gantt-nav-button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-align: center;
    }

    .gantt-nav-label-desktop,
    .gantt-nav-date-desktop,
    .gantt-nav-copy {
        display: none;
    }

    .gantt-nav-label-mobile,
    .gantt-nav-date-mobile {
        display: inline;
    }

    .gantt-nav-label-mobile {
        font-size: 18px;
        font-weight: 700;
        line-height: 1;
    }

    .gantt-nav-date-mobile {
        font-size: 16px;
        line-height: 1.1;
    }

    .charging-card-rate-row,
    .charging-live-metrics {
        grid-template-columns: 1fr;
    }

    .charging-card-head,
    .charging-reservation-chip,
    .charging-session-history-row,
    .charging-session-history-meta {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
    }

    .charging-card-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .voucher-portal-header,
    .overview-voucher-queue-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .charging-card-actions .inline-form,
    .charging-card-actions .primary-button,
    .charging-card-actions .ghost-button,
    .charging-reservation-notes {
        width: 100%;
    }

    .overview-group-media,
    .overview-next-booking-hero,
    .booking-modal-hero {
        grid-template-columns: 1fr;
    }

    .booking-log-grid {
        grid-template-columns: 1fr;
    }

    .instructor-fee-summary-grid {
        grid-template-columns: 1fr;
    }

    .instructor-fee-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .instructor-fee-row,
    .subscription-history-row,
    .instructor-fee-meta,
    .subscription-history-meta,
    .booking-conditional-head {
        justify-content: flex-start;
        justify-items: start;
        text-align: left;
    }

    .accounting-row-card {
        flex-direction: column;
        align-items: flex-start;
    }

    .accounting-row-meta {
        justify-content: flex-start;
        justify-items: start;
        text-align: left;
    }

    .invoice-accounting-header-actions,
    .invoice-inline-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .subscription-history-actions {
        width: auto;
        justify-content: flex-start;
    }

    .invoice-report-form,
    .accounting-stats-grid,
    .instructor-fee-select-row,
    .invoice-accounting-grid {
        grid-template-columns: 1fr;
    }

    .bookings-search-form,
    .bookings-search-actions,
    .member-invite-card,
    .member-toolbar-actions,
    .booking-action-buttons {
        flex-direction: column;
        align-items: stretch;
    }

    .member-invite-actions {
        justify-content: stretch;
    }

    .member-invite-actions .ghost-button {
        width: 100%;
    }

    .messages-page-actions {
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        flex-wrap: wrap;
    }

    .calendar-selection-buttons {
        flex-direction: row;
        align-items: stretch;
        width: 100%;
    }

    .calendar-selection-buttons > * {
        flex: 1 1 0;
        min-width: 0;
    }

    .member-blackout-card {
        flex-direction: column;
        align-items: stretch;
    }

    .member-list-main {
        grid-template-columns: 1fr;
    }

    .member-list-avatar {
        width: 52px;
        height: 52px;
    }

    .member-list-head,
    .member-list-meta {
        flex-direction: column;
        align-items: flex-start;
    }

    .calendar-aircraft-picker {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .calendar-aircraft-help {
        display: none;
    }

    .calendar-aircraft-select-form {
        display: block;
    }

    .calendar-aircraft-picker {
        display: none;
    }

    .calendar-gantt-toolbar,
    .calendar-gantt-weekbar {
        align-items: stretch;
    }

    .calendar-gantt-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .calendar-gantt-filters .form-field,
    .calendar-gantt-aircraft-card {
        min-width: 0;
        width: 100%;
    }

    .calendar-gantt-aircraft-card {
        grid-template-columns: 1fr;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .aircraft-file-item,
    .aircraft-editor-file-item {
        align-items: flex-start;
        flex-direction: column;
    }

    .aircraft-file-actions,
    .aircraft-editor-file-actions {
        width: 100%;
    }

    .booking-row {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .booking-actions {
        width: 100%;
        align-items: stretch;
        justify-content: stretch;
    }

    .invoice-refund-grid,
    .invoice-card .panel-header,
    .invoice-card-actions,
    .bookings-search-form {
        grid-template-columns: 1fr;
        flex-direction: column;
        align-items: stretch;
    }

    .booking-inline-note {
        max-width: none;
        text-align: left;
    }

    .calendar-table,
    .data-table {
        min-width: 680px;
    }

    .topbar {
        height: 60px;
        padding: 0 14px;
    }

    .topbar-brand img:first-child {
        width: auto;
        height: 28px;
        max-width: 34px;
    }

    .topbar-brand img:last-child {
        width: 104px;
    }

    .page-content {
        min-height: calc(100dvh - 60px);
        padding: 80px 16px 18px;
    }
}

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

    .invoice-stats-grid .stat-card:nth-child(-n+3) {
        grid-column: span 2;
    }

    .invoice-stats-grid .stat-card:nth-child(n+4) {
        grid-column: span 3;
    }

    .accounting-stats-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .charging-search-shell {
        min-width: 0;
    }

    .voucher-search-shell {
        min-width: 0;
    }

    .charging-list-card {
        padding: 14px 16px;
        gap: 12px;
    }

    .charging-card-mobile-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        width: 100%;
        padding: 0;
        border: 0;
        background: none;
        text-align: left;
        color: inherit;
        font: inherit;
        cursor: pointer;
    }

    .charging-card-mobile-toggle-copy {
        display: grid;
        gap: 4px;
        min-width: 0;
    }

    .charging-card-mobile-toggle-copy strong {
        font-size: 18px;
        line-height: 1.2;
    }

    .charging-card-body {
        display: none;
    }

    .charging-list-card.is-open .charging-card-body {
        display: grid;
    }

    .charging-card-head {
        display: none;
    }

    .charging-card-rate-row {
        grid-template-columns: 1fr;
    }

    .charging-card-actions {
        flex-direction: row;
        align-items: stretch;
        flex-wrap: nowrap;
    }

    .charging-card-actions .inline-form {
        flex: 1 1 auto;
    }

    .charging-card-actions .inline-form .primary-button {
        width: 100%;
    }

    .charging-card-action-icons {
        flex: 0 0 auto;
        flex-wrap: nowrap;
        gap: 8px;
    }

    .charging-card-action-icons .charging-icon-button {
        width: 44px;
        min-width: 44px;
        height: 44px;
    }

    .charging-card-actions .ghost-button,
    .charging-reservation-notes {
        width: auto;
    }

    .overview-gantt-shell,
    .calendar-gantt-shell,
    .calendar-gantt-empty {
        padding: 16px 12px;
    }

    .overview-gantt-row,
    .calendar-gantt-row {
        overflow: visible;
        contain: none;
    }

    .overview-gantt-row-heading,
    .calendar-gantt-row-heading {
        position: sticky;
        left: 0;
        z-index: 4;
        display: inline-flex;
        justify-self: start;
        justify-content: flex-start;
        width: fit-content;
        max-width: 100%;
        padding: 0 0 2px;
        background: rgba(255, 255, 255, 0.96);
    }

    .overview-gantt-row-aircraft {
        gap: 8px;
    }

    .overview-gantt-row-thumb {
        width: 28px;
        height: 28px;
        border-radius: 10px;
    }

    .overview-gantt-row-heading strong,
    .calendar-gantt-row-heading strong {
        font-size: 16px;
    }

    .overview-gantt-row-heading span,
    .calendar-gantt-row-heading span {
        font-size: 11px;
        line-height: 1.2;
    }

    .calendar-gantt-aircraft-card {
        grid-template-columns: 46px 1fr;
        padding: 12px 14px;
        gap: 10px;
        align-items: center;
    }

    .calendar-gantt-aircraft-card strong {
        font-size: 18px;
    }

    .calendar-gantt-aircraft-card span {
        font-size: 11px;
        line-height: 1.2;
    }

    .calendar-gantt-aircraft-thumb {
        min-height: 38px;
        height: 38px;
        border-radius: 10px;
    }

    .overview-gantt-scale-marker,
    .calendar-gantt-scale-marker {
        font-size: 13px;
    }

    .mobile-gantt-scale-stick {
        position: fixed;
        z-index: 65;
        padding: 6px 0 4px;
        border-radius: 0;
        border: 0;
        background: rgba(255, 255, 255, 0.97);
        box-shadow: 0 10px 24px rgba(27, 30, 31, 0.1);
        backdrop-filter: blur(10px);
        overflow: hidden;
        pointer-events: none;
    }

    .mobile-gantt-scale-stick .overview-gantt-scale,
    .mobile-gantt-scale-stick .calendar-gantt-scale {
        height: 28px;
    }

    .overview-gantt-track {
        min-height: 76px;
    }

    .voucher-gantt-card .overview-gantt-track {
        min-height: 80px;
    }

    .overview-gantt-bar {
        top: 10px;
        bottom: 10px;
        padding: 7px 10px;
        gap: 2px;
    }

    .voucher-gantt-card .overview-gantt-bar {
        top: 10px;
        bottom: 10px;
        padding: 7px 10px 7px 16px;
        gap: 2px;
    }

    .calendar-gantt-track {
        min-height: 68px;
    }

    .calendar-gantt-track-interactive {
        min-height: 84px;
    }

    .calendar-gantt-bar {
        top: 10px;
        bottom: 10px;
        padding: 7px 10px 7px 18px;
        gap: 2px;
    }

    .invoice-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .invoice-stats-grid .stat-card {
        grid-column: span 1 !important;
        padding: 12px 14px;
        border-radius: 18px;
    }

    .invoice-stats-grid .stat-card span {
        margin-bottom: 5px;
        font-size: 10px;
        line-height: 1.15;
    }

    .invoice-stats-grid .stat-card strong {
        font-size: 16px;
        line-height: 1.1;
    }

    .invoice-stats-grid .stat-card:last-child {
        grid-column: span 2 !important;
    }
}

@media (max-width: 520px) {
    .invoice-stats-grid {
        gap: 8px;
    }

    .invoice-stats-grid .stat-card {
        padding: 10px 12px;
        border-radius: 16px;
    }

    .invoice-stats-grid .stat-card span {
        margin-bottom: 4px;
        font-size: 9px;
    }

    .invoice-stats-grid .stat-card strong {
        font-size: 15px;
    }
}

@media (max-width: 860px) {
    .accounting-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .accounting-stats-grid .stat-card {
        padding: 12px 14px;
        border-radius: 18px;
    }

    .accounting-stats-grid .stat-card span,
    .instructor-fee-summary-grid .stat-card span {
        margin-bottom: 5px;
        font-size: 10px;
        line-height: 1.15;
    }

    .accounting-stats-grid .stat-card strong,
    .instructor-fee-summary-grid .stat-card strong {
        font-size: 18px;
        line-height: 1.1;
    }
}

@media (max-width: 560px) {
    .accounting-stats-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .accounting-stats-grid .stat-card,
    .instructor-fee-summary-grid .stat-card {
        padding: 10px 12px;
        border-radius: 16px;
    }

    .accounting-stats-grid .stat-card span,
    .instructor-fee-summary-grid .stat-card span {
        margin-bottom: 4px;
        font-size: 9px;
    }

    .accounting-stats-grid .stat-card strong,
    .instructor-fee-summary-grid .stat-card strong {
        font-size: 16px;
    }
}

.member-tablet-link-card {
    display: grid;
    gap: 14px;
}

.member-group-image-preview {
    display: grid;
    gap: 8px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid var(--av-border);
    background: var(--av-panel-soft);
}

.member-group-image-preview img {
    width: 100%;
    max-width: none;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.member-group-settings-identity {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 16px;
}

.member-group-image-preview-icon {
    width: 76px;
    min-width: 76px;
    padding: 9px;
    justify-items: center;
    text-align: center;
}

.member-group-image-preview-icon img {
    width: 55px;
    height: 55px;
    aspect-ratio: 1 / 1;
    border-radius: 14px;
}

.member-group-name-field {
    margin: 0;
}

@media (max-width: 700px) {
    .member-group-settings-identity {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .member-group-image-preview-icon {
        width: 100%;
        min-width: 0;
        justify-items: start;
        text-align: left;
    }
}

.member-tablet-link-actions {
    align-items: flex-start;
}

.tablet-body {
    margin: 0;
    min-height: 100vh;
    background:
        radial-gradient(circle at top left, rgba(179, 240, 0, 0.16), transparent 34%),
        linear-gradient(180deg, #f6f8ef 0%, #eef2e4 100%);
}

.tablet-page-shell {
    width: min(920px, calc(100vw - 28px));
    margin: 0 auto;
    padding: 18px 0 28px;
}

.tablet-page-intro {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.tablet-page-intro h1 {
    margin: 0 0 8px;
}

.tablet-page-intro p {
    margin: 0;
}

.tablet-page-intro-chips {
    margin-top: 14px;
}

.tablet-page-actions {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.tablet-logs-modal-card {
    width: min(860px, calc(100vw - 28px));
}

.tablet-logs-list {
    display: grid;
    gap: 10px;
    max-height: min(68vh, 760px);
    overflow: auto;
    padding-right: 4px;
}

.tablet-log-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 14px;
}

.tablet-log-empty-state {
    margin-bottom: 14px;
}

.tablet-log-card {
    border: 1px solid rgba(27, 30, 31, 0.08);
    border-radius: 18px;
    background: rgba(179, 240, 0, 0.08);
    overflow: hidden;
}

.tablet-log-toggle {
    width: 100%;
    border: 0;
    background: transparent;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    text-align: left;
    cursor: pointer;
}

.tablet-log-toggle-copy {
    display: grid;
    gap: 4px;
}

.tablet-log-toggle-copy strong,
.tablet-log-toggle-copy span,
.tablet-log-toggle-state {
    display: block;
}

.tablet-log-toggle-copy span,
.tablet-log-toggle-state {
    color: var(--av-muted);
}

.tablet-log-toggle-state {
    font-size: 14px;
    white-space: nowrap;
}

.tablet-log-details {
    display: none;
    padding: 0 16px 16px;
    border-top: 1px solid rgba(27, 30, 31, 0.08);
}

.tablet-log-details.is-open {
    display: block;
}

.tablet-log-details dd {
    overflow-wrap: anywhere;
}

.checkout-board {
    display: grid;
    gap: 18px;
}

.checkout-board-header {
    align-items: flex-start;
    gap: 16px;
}

.checkout-date-controls {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.checkout-date-step {
    min-width: 54px;
    justify-content: center;
    font-size: 15px;
}

.checkout-date-picker {
    margin: 0;
}

.checkout-date-picker input[type="date"] {
    min-width: 188px;
    padding: 13px 16px;
    border-radius: 18px;
    border: 1px solid rgba(27, 30, 31, 0.12);
    background: #ffffff;
    font: inherit;
    color: var(--av-text);
}

.checkout-aircraft-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.checkout-list {
    display: grid;
    gap: 14px;
}

.checkout-card {
    border: 1px solid rgba(27, 30, 31, 0.08);
    border-radius: 24px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 16px 40px rgba(27, 30, 31, 0.08);
}

.checkout-card.is-checked-out {
    border-color: rgba(179, 240, 0, 0.34);
}

.checkout-card-toggle {
    width: 100%;
    border: 0;
    background: transparent;
    padding: 0;
    display: grid;
    grid-template-columns: 168px minmax(0, 1fr) auto;
    align-items: stretch;
    text-align: left;
    cursor: pointer;
}

.checkout-time-rail {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    min-height: 110px;
    padding: 18px 34px 18px 18px;
    background: linear-gradient(180deg, rgba(179, 240, 0, 0.32), rgba(179, 240, 0, 0.16));
    clip-path: polygon(0 0, calc(100% - 26px) 0, 100% 50%, calc(100% - 26px) 100%, 0 100%);
}

.checkout-time-rail strong {
    font-size: 20px;
    line-height: 1.2;
}

.checkout-card-copy {
    display: grid;
    align-content: center;
    gap: 6px;
    padding: 18px 20px;
}

.checkout-card-head {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    align-items: center;
}

.checkout-card-head strong {
    font-size: 20px;
}

.checkout-card-head span,
.checkout-card-meta span {
    color: var(--av-muted);
}

.checkout-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
}

.checkout-card-toggle .status-pill {
    align-self: center;
    margin: 18px;
}

.checkout-card-body {
    display: none;
    padding: 0 20px 20px;
    border-top: 1px solid rgba(27, 30, 31, 0.08);
}

.checkout-card.is-open .checkout-card-body {
    display: block;
}

.checkout-passenger-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}

.checkout-no-passengers {
    margin: 0;
}

.checkout-signature-panel {
    display: grid;
    gap: 12px;
    padding: 16px;
    border-radius: 20px;
    background: rgba(27, 30, 31, 0.04);
}

.checkout-signature-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.checkout-signature-head strong,
.checkout-signature-head span {
    display: block;
}

.checkout-signature-head span {
    margin-top: 4px;
    color: var(--av-muted);
}

.checkout-signature-canvas-wrap {
    min-height: 190px;
    border-radius: 18px;
    border: 1px solid rgba(27, 30, 31, 0.12);
    background: #ffffff;
    overflow: hidden;
}

.checkout-signature-canvas-wrap canvas {
    display: block;
    width: 100%;
    height: 190px;
    touch-action: none;
}

.checkout-signature-display {
    display: grid;
    gap: 12px;
    margin-top: 16px;
}

.checkout-signature-display strong {
    display: block;
}

.checkout-signature-image-wrap {
    border-radius: 18px;
    border: 1px solid rgba(27, 30, 31, 0.12);
    background: #ffffff;
    overflow: hidden;
}

.checkout-signature-image-wrap img {
    display: block;
    width: 100%;
    height: auto;
}

.checkout-form-actions {
    align-items: center;
}

.flight-log-page-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.flight-log-checkout-modal-card {
    width: min(940px, calc(100vw - 28px));
}

@media (max-width: 980px) {
    .tablet-page-shell {
        width: min(100vw - 18px, 100%);
        padding: 12px 0 20px;
    }

    .tablet-page-intro,
    .checkout-board-header {
        flex-direction: column;
        align-items: stretch;
    }

    .tablet-page-actions,
    .checkout-date-controls {
        width: 100%;
    }

    .checkout-date-picker {
        flex: 1 1 auto;
    }

    .checkout-date-picker input[type="date"] {
        width: 100%;
        min-width: 0;
    }

    .checkout-card-toggle {
        grid-template-columns: 1fr;
    }

    .checkout-time-rail {
        min-height: 0;
        padding: 14px 18px 14px 18px;
        clip-path: polygon(0 0, 100% 0, 100% calc(100% - 18px), 50% 100%, 0 calc(100% - 18px));
    }

    .checkout-card-toggle .status-pill {
        justify-self: flex-start;
        margin: 0 20px 18px;
    }
}

@media (max-width: 680px) {
    .tablet-page-shell {
        width: calc(100vw - 14px);
    }

    .checkout-aircraft-filters {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .checkout-aircraft-filters .ghost-button {
        justify-content: center;
    }

    .checkout-card-copy {
        padding: 16px;
    }

    .checkout-card-head strong {
        font-size: 17px;
    }

    .checkout-time-rail strong {
        font-size: 18px;
    }

    .checkout-card-body {
        padding: 0 16px 16px;
    }

    .checkout-signature-panel {
        padding: 14px;
    }

    .checkout-signature-head,
    .checkout-form-actions,
    .tablet-log-toggle {
        flex-direction: column;
        align-items: stretch;
    }

    .tablet-log-toggle-state {
        white-space: normal;
    }
}

@media (max-width: 700px) {
    .overview-announcement-bar,
    .overview-setting-card,
    .overview-welcome-header {
        align-items: stretch;
    }

    .overview-announcement-actions,
    .overview-setting-card {
        width: 100%;
    }

    .overview-announcement-actions {
        justify-content: stretch;
    }

    .overview-announcement-actions .ghost-button,
    .overview-announcement-actions .primary-button {
        flex: 1 1 100%;
    }

    .overview-settings-button {
        align-self: flex-end;
    }
}

html[data-theme="dark"] {
    color-scheme: dark;
    --av-dark: #060809;
    --av-dark-soft: #13181a;
    --av-panel: #101619;
    --av-panel-soft: #161f23;
    --av-text: #edf3f4;
    --av-muted: #9aabb0;
    --av-border: #2c373b;
    --av-shadow: 0 20px 56px rgba(0, 0, 0, 0.42);
}

html[data-theme="dark"],
html[data-theme="dark"] body {
    background: linear-gradient(180deg, #081013 0%, #11181b 55%, #0b1113 100%);
    color: var(--av-text);
}

html[data-theme="dark"] .auth-body,
html[data-theme="dark"] .setup-body {
    background:
        radial-gradient(circle at top left, rgba(179, 240, 0, 0.18), transparent 34%),
        linear-gradient(180deg, #081013 0%, #11181b 55%, #0b1113 100%);
}

html[data-theme="dark"] .auth-panel {
    background: rgba(8, 12, 14, 0.92);
    border: 1px solid #333333;
}

html[data-theme="dark"] .auth-card,
html[data-theme="dark"] .setup-card {
    background: linear-gradient(180deg, rgba(17, 24, 27, 0.98), rgba(9, 13, 15, 0.98));
    border-color: var(--av-border);
    color: var(--av-text);
}

html[data-theme="dark"] .auth-brand {
    background: linear-gradient(145deg, #0b0f11 0%, #1a2123 100%);
}

html[data-theme="dark"] .auth-brand-login {
    background:
        radial-gradient(circle at center, rgba(126, 57, 255, 0.22) 0%, rgba(14, 9, 29, 0.94) 58%, #06080a 100%);
}

html[data-theme="dark"] .auth-brand-copy {
    color: rgba(237, 243, 244, 0.72);
}

html[data-theme="dark"] .auth-invite-card {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--av-border);
}

html[data-theme="dark"] .auth-invite-card-disabled {
    background: rgba(169, 46, 46, 0.12);
    border-color: rgba(232, 149, 162, 0.18);
}

html[data-theme="dark"] .topbar {
    background: linear-gradient(180deg, #0d1112 0%, #151b1d 100%);
    border-bottom-color: rgba(179, 240, 0, 0.2);
}

html[data-theme="dark"] .sidebar {
    background: linear-gradient(180deg, #0b0f11 0%, #141a1c 100%);
    border-right-color: rgba(179, 240, 0, 0.18);
}

html[data-theme="dark"] .topbar-toggle,
html[data-theme="dark"] .sidebar-view-button,
html[data-theme="dark"] .sidebar-close,
html[data-theme="dark"] .topbar-brand,
html[data-theme="dark"] .sidebar-user,
html[data-theme="dark"] .sidebar-group-switch {
    border-color: rgba(255, 255, 255, 0.12);
}

html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .panel-card,
html[data-theme="dark"] .aircraft-card,
html[data-theme="dark"] .member-card,
html[data-theme="dark"] .auth-card,
html[data-theme="dark"] .setup-card,
html[data-theme="dark"] .modal-card {
    border-color: rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .modal-shell {
    background: rgba(2, 4, 5, 0.84);
}

html[data-theme="dark"] .modal-card {
    background: #0a0f11;
    color: var(--av-text);
    box-shadow: 0 34px 82px rgba(0, 0, 0, 0.62);
}

html[data-theme="dark"] .ghost-button,
html[data-theme="dark"] .overview-gantt-date-pill,
html[data-theme="dark"] .calendar-gantt-week-pill,
html[data-theme="dark"] .topbar-toggle,
html[data-theme="dark"] .sidebar-view-button,
html[data-theme="dark"] .sidebar-close,
html[data-theme="dark"] .weather-block,
html[data-theme="dark"] .message-bubble,
html[data-theme="dark"] .member-list-item,
html[data-theme="dark"] .overview-setting-card,
html[data-theme="dark"] .overview-landaway-route-card,
html[data-theme="dark"] .flight-log-image-link {
    background: rgba(255, 255, 255, 0.04);
    color: var(--av-text);
    border-color: var(--av-border);
}

html[data-theme="dark"] .primary-button,
html[data-theme="dark"] .bookings-view-switch .ghost-button.is-active,
html[data-theme="dark"] .weather-toggle.is-active,
html[data-theme="dark"] .invoice-filter-switch .ghost-button.is-active,
html[data-theme="dark"] .member-filter-switch .ghost-button.is-active,
html[data-theme="dark"] .calendar-aircraft-tile.is-active {
    color: #111518;
}

html[data-theme="dark"] .calendar-aircraft-tile.is-active p,
html[data-theme="dark"] .calendar-aircraft-tile.is-active span,
html[data-theme="dark"] .calendar-aircraft-tile.is-active strong {
    color: #111518;
}

html[data-theme="dark"] .bookings-icon-button span,
html[data-theme="dark"] .messages-icon-button span,
html[data-theme="dark"] .charging-icon-button span,
html[data-theme="dark"] .member-settings-button span,
html[data-theme="dark"] .overview-settings-button span,
html[data-theme="dark"] .auth-settings-button span {
    color: var(--av-text);
}

html[data-theme="dark"] .filter-form input,
html[data-theme="dark"] .filter-form select,
html[data-theme="dark"] .auth-form input,
html[data-theme="dark"] .auth-form select,
html[data-theme="dark"] .bookings-search-form input,
html[data-theme="dark"] .invoice-report-form input,
html[data-theme="dark"] .invoice-accounting-modal-search input,
html[data-theme="dark"] .stack-form input,
html[data-theme="dark"] .stack-form select,
html[data-theme="dark"] .stack-form textarea,
html[data-theme="dark"] .voucher-assign-form input,
html[data-theme="dark"] .voucher-assign-form select,
html[data-theme="dark"] .sidebar-group-switch select {
    background: #0d1316;
    color: var(--av-text);
    border-color: var(--av-border);
}

html[data-theme="dark"] input[type="date"] {
    background: #0d1316;
    color: var(--av-text);
    border-color: var(--av-border);
    color-scheme: dark;
}

html[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator {
    filter: brightness(0) invert(1) !important;
    opacity: 1 !important;
    color: #ffffff !important;
}

html[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator:hover,
html[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator:focus {
    filter: brightness(0) invert(1) !important;
    opacity: 1 !important;
    color: #ffffff !important;
}

html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder {
    color: #7f9196;
}

html[data-theme="dark"] .panel-header a,
html[data-theme="dark"] .auth-secondary-link a,
html[data-theme="dark"] .auth-card p,
html[data-theme="dark"] .auth-invite-card span,
html[data-theme="dark"] .auth-invite-card p,
html[data-theme="dark"] .overview-announcement-copy span,
html[data-theme="dark"] .overview-setting-copy span,
html[data-theme="dark"] .overview-settings-note,
html[data-theme="dark"] .overview-stat-pill span,
html[data-theme="dark"] .message-bubble-meta span,
html[data-theme="dark"] .overview-gantt-scale-marker,
html[data-theme="dark"] .overview-gantt-row-heading span,
html[data-theme="dark"] .overview-group-media p,
html[data-theme="dark"] .overview-route-fallback-caption,
html[data-theme="dark"] .empty-state,
html[data-theme="dark"] .list-row span,
html[data-theme="dark"] .booking-copy span {
    color: var(--av-muted);
}

html[data-theme="dark"] .overview-announcement-bar {
    border-color: rgba(179, 240, 0, 0.24);
    background:
        linear-gradient(135deg, rgba(179, 240, 0, 0.14), rgba(179, 240, 0, 0.03)),
        var(--av-panel);
}

html[data-theme="dark"] .overview-group-card {
    --overview-group-overlay: linear-gradient(90deg, rgba(7, 10, 11, 0.97) 0%, rgba(8, 12, 13, 0.92) 18%, rgba(9, 13, 15, 0.62) 36%, rgba(9, 13, 15, 0.24) 54%, rgba(9, 13, 15, 0) 68%);
}

html[data-theme="dark"] .overview-group-card::before {
    background-image: var(--overview-group-overlay), var(--overview-group-image);
}

html[data-theme="dark"] .overview-group-meta span {
    background: rgba(8, 12, 13, 0.72);
    border-color: rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"] .overview-gantt-track {
    border-color: rgba(255, 255, 255, 0.08);
    background:
        repeating-linear-gradient(
            to right,
            rgba(255, 255, 255, 0.08) 0,
            rgba(255, 255, 255, 0.08) 1px,
            transparent 1px,
            transparent calc(100% / var(--overview-slot-count, 21))
        ),
        linear-gradient(180deg, #11181b 0%, #0a0f11 100%);
}

html[data-theme="dark"] .calendar-gantt-track {
    border-color: rgba(255, 255, 255, 0.08);
    background:
        repeating-linear-gradient(
            to right,
            rgba(255, 255, 255, 0.08) 0,
            rgba(255, 255, 255, 0.08) 1px,
            transparent 1px,
            transparent calc(100% / var(--calendar-slot-count, 21))
        ),
        linear-gradient(180deg, #12191c 0%, #0a1012 100%);
}

html[data-theme="dark"] .calendar-slot-button {
    border-right-color: rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"] .calendar-slot-button.is-selected {
    box-shadow: inset 0 0 0 2px rgba(7, 10, 11, 0.36);
}

html[data-theme="dark"] .calendar-slot-button.is-past-locked {
    background: rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .calendar-selection-count-box {
    background: rgba(255, 255, 255, 0.04);
    border-color: var(--av-border);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.05);
    color: var(--av-text);
}

html[data-theme="dark"] .calendar-selection-count-box strong {
    color: var(--av-text);
}

html[data-theme="dark"] .charging-live-card,
html[data-theme="dark"] .charging-reservation-chip,
html[data-theme="dark"] .charging-list-card,
html[data-theme="dark"] .charging-reservation-notes,
html[data-theme="dark"] .voucher-list-card,
html[data-theme="dark"] .invoice-card,
html[data-theme="dark"] .booking-log-card {
    background: linear-gradient(180deg, rgba(20, 28, 31, 0.98), rgba(10, 15, 17, 0.98));
    border-color: var(--av-border);
}

html[data-theme="dark"] .charging-search-suggestions,
html[data-theme="dark"] .voucher-search-suggestions {
    background: #0b1012;
    border-color: var(--av-border);
    box-shadow: 0 22px 44px rgba(0, 0, 0, 0.5);
}

html[data-theme="dark"] .charging-search-suggestion:hover,
html[data-theme="dark"] .charging-search-suggestion:focus-visible,
html[data-theme="dark"] .voucher-search-suggestion:hover,
html[data-theme="dark"] .voucher-search-suggestion:focus-visible {
    background: rgba(179, 240, 0, 0.18);
}

html[data-theme="dark"] .charging-map-canvas,
html[data-theme="dark"] .charging-map-empty {
    background: linear-gradient(180deg, #11171a 0%, #090d0f 100%);
    border-color: var(--av-border);
}

html[data-theme="dark"] .charging-load-reservations,
html[data-theme="dark"] .flight-log-details {
    border-color: var(--av-border);
}

html[data-theme="dark"] .accounting-row-card {
    background: linear-gradient(180deg, rgba(20, 28, 31, 0.98), rgba(10, 15, 17, 0.98));
    border-color: var(--av-border);
}

html[data-theme="dark"] .weather-toggle {
    color: var(--av-text);
}

html[data-theme="dark"] .weather-toggle.is-active {
    background: var(--av-green);
    border-color: rgba(179, 240, 0, 0.36);
    box-shadow: 0 10px 20px rgba(179, 240, 0, 0.16);
}

html[data-theme="dark"] .weather-clouds span,
html[data-theme="dark"] .taf-period,
html[data-theme="dark"] .overview-next-booking-hero,
html[data-theme="dark"] .overview-booking-list-item,
html[data-theme="dark"] .aircraft-file-item,
html[data-theme="dark"] .aircraft-editor-file-item {
    background: linear-gradient(180deg, rgba(20, 28, 31, 0.98), rgba(10, 15, 17, 0.98));
    border-color: var(--av-border);
    color: var(--av-text);
}

html[data-theme="dark"] .taf-period strong,
html[data-theme="dark"] .taf-period span,
html[data-theme="dark"] .taf-period p,
html[data-theme="dark"] .weather-clouds span,
html[data-theme="dark"] .aircraft-file-copy strong,
html[data-theme="dark"] .aircraft-editor-file-copy strong {
    color: var(--av-text);
}

html[data-theme="dark"] .overview-next-booking-hero p,
html[data-theme="dark"] .overview-booking-list-item span,
html[data-theme="dark"] .aircraft-file-copy span,
html[data-theme="dark"] .aircraft-editor-file-copy span {
    color: var(--av-muted);
}

html[data-theme="dark"] .overview-route-fallback-label,
html[data-theme="dark"] .overview-route-fallback-caption {
    fill: var(--av-text);
}

html[data-theme="dark"] .message-bubble.is-mine {
    background: rgba(179, 240, 0, 0.1);
    border-color: rgba(179, 240, 0, 0.2);
}

html[data-theme="dark"] .message-bubble.is-unread {
    background: rgba(215, 38, 61, 0.08);
    border-color: rgba(215, 38, 61, 0.16);
}

html[data-theme="dark"] .booking-row-voucher,
html[data-theme="dark"] .voucher-portal-request-card {
    background: linear-gradient(180deg, rgba(255, 176, 69, 0.08), rgba(16, 22, 25, 0.96));
}

html[data-theme="dark"] .voucher-payment-note {
    background: linear-gradient(180deg, rgba(179, 240, 0, 0.12), rgba(16, 22, 25, 0.96));
    border-color: rgba(179, 240, 0, 0.24);
}

html[data-theme="dark"] .calendar-table th,
html[data-theme="dark"] .calendar-table td,
html[data-theme="dark"] .data-table th,
html[data-theme="dark"] .data-table td,
html[data-theme="dark"] .meta-list div,
html[data-theme="dark"] .profile-grid div,
html[data-theme="dark"] .list-row,
html[data-theme="dark"] .booking-row,
html[data-theme="dark"] .voucher-portal-divider,
html[data-theme="dark"] .member-settings-divider {
    border-color: var(--av-border);
}

html[data-theme="dark"] .member-group-image-preview {
    background: linear-gradient(180deg, rgba(20, 28, 31, 0.98), rgba(10, 15, 17, 0.98));
    border-color: var(--av-border);
}

html[data-theme="dark"] .member-group-image-preview img {
    border-color: rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"] .leaflet-tile-pane {
    filter: invert(1) hue-rotate(180deg) brightness(0.82) saturate(0.9);
}

html[data-theme="dark"] .leaflet-popup-content-wrapper,
html[data-theme="dark"] .leaflet-popup-tip,
html[data-theme="dark"] .leaflet-control-zoom a {
    background: var(--av-panel);
    color: var(--av-text);
    border-color: var(--av-border);
}

html[data-theme="dark"] .checkout-card {
    background: linear-gradient(180deg, rgba(18, 25, 28, 0.96), rgba(10, 15, 17, 0.98));
    border-color: rgba(255, 255, 255, 0.07);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.34);
}

html[data-theme="dark"] .checkout-card-body {
    border-top-color: rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"] .checkout-time-rail {
    background: linear-gradient(180deg, rgba(179, 240, 0, 0.24), rgba(179, 240, 0, 0.1));
}

html[data-theme="dark"] .checkout-card-head span,
html[data-theme="dark"] .checkout-card-meta span,
html[data-theme="dark"] .checkout-signature-head span,
html[data-theme="dark"] .checkout-date-picker input[type="date"] {
    color: var(--av-muted);
}

html[data-theme="dark"] .checkout-date-picker input[type="date"],
html[data-theme="dark"] .checkout-signature-panel,
html[data-theme="dark"] .checkout-signature-canvas-wrap,
html[data-theme="dark"] .checkout-signature-image-wrap {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"] .auth-card h1,
html[data-theme="dark"] .auth-card strong {
    color: var(--av-text);
}

html[data-theme="dark"] .auth-login-prefix,
html[data-theme="dark"] .auth-form label {
    color: var(--av-muted);
}

html[data-theme="dark"] .flash-error {
    background: rgba(169, 46, 46, 0.18);
    color: #f2b4bf;
}

html[data-theme="dark"] .flash-success {
    background: rgba(42, 122, 59, 0.18);
    color: #bff0c9;
}

html[data-theme="dark"] .flash-warning {
    background: rgba(232, 149, 162, 0.18);
    color: #ffd4dc;
}

html[data-theme="dark"] .auth-form input:-webkit-autofill,
html[data-theme="dark"] .auth-form input:-webkit-autofill:hover,
html[data-theme="dark"] .auth-form input:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--av-text);
    box-shadow: 0 0 0 1000px #0d1316 inset;
    transition: background-color 9999s ease-out 0s;
    caret-color: var(--av-text);
}

.invoice-tax-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    padding-top: 8px;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    color: var(--muted-copy);
    font-size: 0.92rem;
}

.invoice-tax-summary strong {
    color: inherit;
}

html[data-theme="dark"] .invoice-tax-summary {
    border-top-color: rgba(255, 255, 255, 0.08);
    color: var(--av-muted);
}

@media (max-width: 760px) {
    html[data-theme="dark"] .overview-gantt-row-heading,
    html[data-theme="dark"] .calendar-gantt-row-heading {
        background: rgba(9, 13, 15, 0.96);
    }

    html[data-theme="dark"] .mobile-gantt-scale-stick {
        background: rgba(9, 13, 15, 0.97);
        box-shadow: 0 12px 28px rgba(0, 0, 0, 0.44);
    }
}
