/* === BASE RESET & TYPOGRAPHY ===
   Loaded on every page. Single source of truth for fonts, buttons, topbar. */
:root {
    --page-max-width: 1400px;

    /* Colours */
    --color-primary: #0072ce;
    --color-primary-bg: #009fe3;
    --color-primary-border: #0080b8;
    --color-primary-text: #ffffff;

    --color-danger: #dc2626;
    --color-danger-bg: #fee2e2;
    --color-danger-text: #991b1b;
    --color-danger-border: #fca5a5;

    --color-neutral-bg: #e8f0f5;
    --color-neutral-text: #1a3a50;
    --color-neutral-border: #a0bece;

    --color-pdf-bg: #d1fae5;
    --color-pdf-text: #065f46;
    --color-pdf-border: #6ee7b7;

    --color-outline-bg: #ffffff;
    --color-outline-text: #1e293b;
    --color-outline-border: #d1d5db;

    --color-text: #1e293b;
    --color-text-secondary: #6b7280;
    --color-link: #0072ce;
    --color-border: #e5e7eb;
    --color-border-light: #f1f3f5;
    --color-bg-subtle: #f9fafb;
    --color-surface: #ffffff;
    --color-hover: #f0f7ff;

    /* Table header */
    --color-th-bg: #f2f2f2;
    --color-th-text: #1e293b;
    --color-th-border: #d9d9d9;

    --color-warning: #f59e0b;
    --color-info: #0891b2;

    /* Shadows */
    --shadow-card: 0 2px 12px rgba(0, 0, 0, 0.05);
    --shadow-btn-hover: 0 4px 16px rgba(0, 0, 0, 0.35);

    /* Radius */
    --radius-card: 14px;
    --radius-btn: 8px;
    --radius-sm: 8px;
    --radius-input: 8px;

    /* Transition */
    --transition-base: 0.18s ease;

    /* Typography */
    --font-btn: 13px;
    --font-weight-btn: 500;
}

/* ═══════════════════════════════════════════════
   COLOUR SCHEME PALETTE OVERRIDES
   ═══════════════════════════════════════════════ */
[data-palette="berry_soft"] {
    --color-primary-bg:     #f5e8ed;
    --color-primary-border: #c07890;
    --color-primary-text:   #6a1830;
    --color-danger-bg:      #fdf0e0;
    --color-danger-border:  #d09040;
    --color-danger-text:    #6a3000;
    --color-neutral-bg:     #ededee;
    --color-neutral-border: #b8b0b8;
    --color-neutral-text:   #382838;
    --color-pdf-bg:         #e0e4f0;
    --color-pdf-border:     #8090c0;
    --color-pdf-text:       #283060;
    --color-th-bg:          #ede8f5;
    --color-th-border:      #b8a8d8;
    --color-th-text:        #6a1830;
}
[data-palette="scholar_soft"] {
    --color-primary-bg:     #f8f0cc;
    --color-primary-border: #c8a020;
    --color-primary-text:   #4a3000;
    --color-danger-bg:      #fde8e0;
    --color-danger-border:  #d05030;
    --color-danger-text:    #580800;
    --color-neutral-bg:     #f4f3ea;
    --color-neutral-border: #c0c0b0;
    --color-neutral-text:   #303030;
    --color-pdf-bg:         #d8dce8;
    --color-pdf-border:     #506080;
    --color-pdf-text:       #1a2840;
    --color-th-bg:          #e4e8ed;
    --color-th-border:      #909cb0;
    --color-th-text:        #333d51;
}
[data-palette="harbor_soft"] {
    --color-primary-bg:     #d8eaea;
    --color-primary-border: #508888;
    --color-primary-text:   #1a3838;
    --color-danger-bg:      #fde8e0;
    --color-danger-border:  #d06040;
    --color-danger-text:    #5a1800;
    --color-neutral-bg:     #e8edef;
    --color-neutral-border: #a8b8c0;
    --color-neutral-text:   #283438;
    --color-pdf-bg:         #fdf0c0;
    --color-pdf-border:     #c89020;
    --color-pdf-text:       #4a3000;
    --color-th-bg:          #dceeed;
    --color-th-border:      #70b0ae;
    --color-th-text:        #1a3838;
}
[data-palette="gecko_soft"] {
    --color-primary-bg:     #f0e4f5;
    --color-primary-border: #a860b8;
    --color-primary-text:   #5a1870;
    --color-danger-bg:      #fde8d8;
    --color-danger-border:  #d06030;
    --color-danger-text:    #5a1800;
    --color-neutral-bg:     #ededee;
    --color-neutral-border: #b0b0b8;
    --color-neutral-text:   #303038;
    --color-pdf-bg:         #f0f8c0;
    --color-pdf-border:     #a0b020;
    --color-pdf-text:       #303800;
    --color-th-bg:          #ede4f0;
    --color-th-border:      #c090d0;
    --color-th-text:        #5a1870;
}
[data-palette="brisk_soft"] {
    --color-primary-bg:     #f5dde5;
    --color-primary-border: #b05070;
    --color-primary-text:   #5a0820;
    --color-danger-bg:      #fde8d0;
    --color-danger-border:  #d07030;
    --color-danger-text:    #5a2000;
    --color-neutral-bg:     #eceaed;
    --color-neutral-border: #a8a0b0;
    --color-neutral-text:   #2c2838;
    --color-pdf-bg:         #d8edf8;
    --color-pdf-border:     #6098d0;
    --color-pdf-text:       #0a3060;
    --color-th-bg:          #fef5d8;
    --color-th-border:      #d8a820;
    --color-th-text:        #4a2800;
}
[data-palette="wine_soft"] {
    --color-primary-bg:     #f0d8ee;
    --color-primary-border: #a840a0;
    --color-primary-text:   #500040;
    --color-danger-bg:      #fde8d0;
    --color-danger-border:  #d07830;
    --color-danger-text:    #5a2000;
    --color-neutral-bg:     #f5efe5;
    --color-neutral-border: #c0b098;
    --color-neutral-text:   #383020;
    --color-pdf-bg:         #faf0cc;
    --color-pdf-border:     #b88820;
    --color-pdf-text:       #483000;
    --color-th-bg:          #eedcee;
    --color-th-border:      #c060b8;
    --color-th-text:        #500040;
}
[data-palette="scuba_soft"] {
    --color-primary-bg:     #c8e8f5;
    --color-primary-border: #2878a0;
    --color-primary-text:   #042030;
    --color-danger-bg:      #fde8d8;
    --color-danger-border:  #d05818;
    --color-danger-text:    #5a1800;
    --color-neutral-bg:     #e8e4e2;
    --color-neutral-border: #a8a0a0;
    --color-neutral-text:   #302828;
    --color-pdf-bg:         #d8f0f8;
    --color-pdf-border:     #60b8d8;
    --color-pdf-text:       #0a3848;
    --color-th-bg:          #dff0f8;
    --color-th-border:      #70c0e0;
    --color-th-text:        #042030;
}
[data-palette="berry_bright"] {
    --color-primary-bg:     #934A5F;
    --color-primary-border: #6a2a3f;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #c85a20;
    --color-danger-border:  #9a3e10;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #57648C;
    --color-neutral-border: #3a4868;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #7a6a9e;
    --color-pdf-border:     #5a4a7e;
    --color-pdf-text:       #ffffff;
    --color-th-bg:          #57648C;
    --color-th-border:      #3a4868;
    --color-th-text:        #ffffff;
}
[data-palette="scholar_bright"] {
    --color-primary-bg:     #333D51;
    --color-primary-border: #1a2030;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #c03020;
    --color-danger-border:  #902010;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #8a9aaa;
    --color-neutral-border: #607080;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #D3AC2B;
    --color-pdf-border:     #a88010;
    --color-pdf-text:       #2a1800;
    --color-th-bg:          #333D51;
    --color-th-border:      #1a2030;
    --color-th-text:        #ffffff;
}
[data-palette="harbor_bright"] {
    --color-primary-bg:     #354649;
    --color-primary-border: #1a2a2c;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #c04820;
    --color-danger-border:  #903010;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #6C7A89;
    --color-neutral-border: #485868;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #c89820;
    --color-pdf-border:     #987010;
    --color-pdf-text:       #ffffff;
    --color-th-bg:          #A3C6C4;
    --color-th-border:      #6aacaa;
    --color-th-text:        #1a3838;
}
[data-palette="gecko_bright"] {
    --color-primary-bg:     #9F4298;
    --color-primary-border: #782878;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #d03828;
    --color-danger-border:  #a02018;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #888898;
    --color-neutral-border: #606070;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #CFDB31;
    --color-pdf-border:     #a0b010;
    --color-pdf-text:       #303800;
    --color-th-bg:          #9F4298;
    --color-th-border:      #782878;
    --color-th-text:        #ffffff;
}
[data-palette="brisk_bright"] {
    --color-primary-bg:     #4C4556;
    --color-primary-border: #2c2838;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #872642;
    --color-danger-border:  #601828;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #8880a0;
    --color-neutral-border: #605878;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #A0D3F9;
    --color-pdf-border:     #60a8e0;
    --color-pdf-text:       #0a2848;
    --color-th-bg:          #F6C026;
    --color-th-border:      #c09000;
    --color-th-text:        #2a1800;
}
[data-palette="condiments_bright"] {
    --color-primary-bg:     #C4BA3B;
    --color-primary-border: #908808;
    --color-primary-text:   #2a2200;
    --color-danger-bg:      #E2495B;
    --color-danger-border:  #b02838;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #909080;
    --color-neutral-border: #686858;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #50a898;
    --color-pdf-border:     #308878;
    --color-pdf-text:       #ffffff;
    --color-th-bg:          #C4BA3B;
    --color-th-border:      #908808;
    --color-th-text:        #2a2200;
}
[data-palette="wine_bright"] {
    --color-primary-bg:     #7F056E;
    --color-primary-border: #580048;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #c03820;
    --color-danger-border:  #902010;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #C09247;
    --color-neutral-border: #907020;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #CAB387;
    --color-pdf-border:     #907848;
    --color-pdf-text:       #2a1800;
    --color-th-bg:          #7F056E;
    --color-th-border:      #580048;
    --color-th-text:        #ffffff;
}
[data-palette="scuba_bright"] {
    --color-primary-bg:     #0C4A60;
    --color-primary-border: #062838;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #EF6C33;
    --color-danger-border:  #c04810;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #8898a0;
    --color-neutral-border: #607080;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #ABDFF1;
    --color-pdf-border:     #60b8d8;
    --color-pdf-text:       #082030;
    --color-th-bg:          #0C4A60;
    --color-th-border:      #062838;
    --color-th-text:        #ffffff;
}
[data-palette="navi_bright"] {
    --color-primary-bg:     #000066;
    --color-primary-border: #000044;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #cc0000;
    --color-danger-border:  #990000;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #3333aa;
    --color-neutral-border: #222288;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #f5c800;
    --color-pdf-border:     #c8a000;
    --color-pdf-text:       #2a1e00;
    --color-th-bg:          #000066;
    --color-th-border:      #000044;
    --color-th-text:        #ffffff;
}
[data-palette="navi_soft"] {
    --color-primary-bg:     #5555bb;
    --color-primary-border: #222288;
    --color-primary-text:   #ffffff;
    --color-danger-bg:      #e03030;
    --color-danger-border:  #b01010;
    --color-danger-text:    #ffffff;
    --color-neutral-bg:     #9999cc;
    --color-neutral-border: #555599;
    --color-neutral-text:   #ffffff;
    --color-pdf-bg:         #f0c000;
    --color-pdf-border:     #bc9400;
    --color-pdf-text:       #2a1800;
    --color-th-bg:          #3333aa;
    --color-th-border:      #111188;
    --color-th-text:        #ffffff;
}

[data-palette="phpstorm_classic"] {
    --color-primary-bg:       #82aaff;
    --color-primary-border:   #4d7ae0;
    --color-primary-text:     #ffffff;
    --color-danger-bg:        #f07a30;
    --color-danger-border:    #b85010;
    --color-danger-text:      #ffffff;
    --color-neutral-bg:       #2d3250;
    --color-neutral-border:   #4a5070;
    --color-neutral-text:     #a8b2d8;
    --color-pdf-bg:           #c3e88d;
    --color-pdf-border:       #8ab840;
    --color-pdf-text:         #1a2800;
    --color-outline-bg:       transparent;
    --color-outline-border:   #82aaff;
    --color-outline-text:     #82aaff;
    --color-th-bg:            #1a1d2e;
    --color-th-border:        #4a5070;
    --color-th-text:          #82aaff;
    --color-text:             #a8b2d8;
    --color-text-secondary:   #8892a8;
    --color-link:             #82aaff;
    --color-border:           #3a4060;
    --color-bg-subtle:        #1e2130;
    --color-hover:            #2a3060;
    --shadow-card:            0 2px 12px rgba(0, 0, 0, 0.5);
    --shadow-btn-hover:       0 4px 16px rgba(130, 170, 255, 0.35);
    --color-success-bg:       #6ee7b7;
    --color-success-border:   #34d399;
    --color-success-text:     #022c22;
    --color-muted-green:      #697a6e;
    --color-page-bg:          #13151f;
    --color-surface:          #1e2130;
    --color-booked-out-bg:    #2a2510;
    --color-booked-out-hover: #3a3518;
    --color-booked-out-banner-bg:     #2a2510;
    --color-booked-out-banner-border: #a07820;
    --color-booked-out-banner-text:   #f0d080;
}

[data-palette="phpstorm_teal"] {
    --color-primary-bg:       #89ddff;
    --color-primary-border:   #3898c8;
    --color-primary-text:     #ffffff;
    --color-danger-bg:        #ff5370;
    --color-danger-border:    #cc2048;
    --color-danger-text:      #ffffff;
    --color-neutral-bg:       #1e3040;
    --color-neutral-border:   #386080;
    --color-neutral-text:     #9ab0c8;
    --color-pdf-bg:           #ffd866;
    --color-pdf-border:       #c8a000;
    --color-pdf-text:         #1e1400;
    --color-outline-bg:       transparent;
    --color-outline-border:   #89ddff;
    --color-outline-text:     #89ddff;
    --color-th-bg:            #0f1a24;
    --color-th-border:        #386080;
    --color-th-text:          #89ddff;
    --color-text:             #9ab0c8;
    --color-text-secondary:   #8892a8;
    --color-link:             #89ddff;
    --color-border:           #284050;
    --color-bg-subtle:        #182030;
    --color-hover:            #1e3850;
    --shadow-card:            0 2px 12px rgba(0, 0, 0, 0.5);
    --shadow-btn-hover:       0 4px 16px rgba(137, 221, 255, 0.35);
    --color-success-bg:       #6ee7b7;
    --color-success-border:   #34d399;
    --color-success-text:     #022c22;
    --color-muted-green:      #697a6e;
    --color-page-bg:          #0d1520;
    --color-surface:          #182030;
    --color-booked-out-bg:    #1a2010;
    --color-booked-out-hover: #283018;
    --color-booked-out-banner-bg:     #1a2010;
    --color-booked-out-banner-border: #6a8830;
    --color-booked-out-banner-text:   #c8e090;
}

/* Text links */
.text-link {
    color: var(--color-link);
    text-decoration: underline;
}
.text-link:hover {
    opacity: 0.8;
}

/* ═══════════════════════════════════════════════
   DARK PALETTE PAGE CHROME
   ═══════════════════════════════════════════════ */
[data-palette="phpstorm_classic"],
[data-palette="phpstorm_teal"] {
    background-color: var(--color-page-bg);
}

[data-palette="phpstorm_classic"] .container,
[data-palette="phpstorm_teal"] .container {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-card);
}

[data-palette="phpstorm_classic"] .topbar,
[data-palette="phpstorm_teal"] .topbar {
    background: var(--color-surface);
    border-bottom-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .users-table-card,
[data-palette="phpstorm_classic"] .add-user-card,
[data-palette="phpstorm_classic"] .add-aircraft-card,
[data-palette="phpstorm_classic"] .add-record-card,
[data-palette="phpstorm_classic"] .add-defect-section,
[data-palette="phpstorm_classic"] .org-settings-card,
[data-palette="phpstorm_classic"] .org-picker-card,
[data-palette="phpstorm_classic"] .finance-filters,
[data-palette="phpstorm_classic"] .logsheet-wrapper,
[data-palette="phpstorm_classic"] .filter-form,
[data-palette="phpstorm_classic"] .modal-panel,
[data-palette="phpstorm_classic"] .add-document-section,
[data-palette="phpstorm_classic"] .membership-card,
[data-palette="phpstorm_teal"] .users-table-card,
[data-palette="phpstorm_teal"] .add-user-card,
[data-palette="phpstorm_teal"] .add-aircraft-card,
[data-palette="phpstorm_teal"] .add-record-card,
[data-palette="phpstorm_teal"] .add-defect-section,
[data-palette="phpstorm_teal"] .org-settings-card,
[data-palette="phpstorm_teal"] .org-picker-card,
[data-palette="phpstorm_teal"] .finance-filters,
[data-palette="phpstorm_teal"] .logsheet-wrapper,
[data-palette="phpstorm_teal"] .filter-form,
[data-palette="phpstorm_teal"] .modal-panel,
[data-palette="phpstorm_teal"] .add-document-section,
[data-palette="phpstorm_teal"] .membership-card {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] input:not([type="checkbox"]):not([type="radio"]):not([type="date"]),
[data-palette="phpstorm_classic"] input[type="date"],
[data-palette="phpstorm_classic"] input[type="number"],
[data-palette="phpstorm_classic"] input[type="text"],
[data-palette="phpstorm_classic"] input[type="time"],
[data-palette="phpstorm_classic"] select,
[data-palette="phpstorm_classic"] textarea,
[data-palette="phpstorm_teal"] input:not([type="checkbox"]):not([type="radio"]):not([type="date"]),
[data-palette="phpstorm_teal"] input[type="date"],
[data-palette="phpstorm_teal"] input[type="number"],
[data-palette="phpstorm_teal"] input[type="text"],
[data-palette="phpstorm_teal"] input[type="time"],
[data-palette="phpstorm_teal"] select,
[data-palette="phpstorm_teal"] textarea {
    background:   var(--color-surface) !important;
    color:        var(--color-text) !important;
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] input[type="date"],
[data-palette="phpstorm_teal"] input[type="date"] {
    color-scheme: dark;
    color:        var(--color-text) !important;
}

[data-palette="phpstorm_classic"] input[type="time"],
[data-palette="phpstorm_teal"] input[type="time"] {
    color-scheme: dark;
    color:        var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .container input,
[data-palette="phpstorm_classic"] .container select,
[data-palette="phpstorm_teal"] .container input,
[data-palette="phpstorm_teal"] .container select {
    background:   var(--color-surface) !important;
    color:        var(--color-text) !important;
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] input:focus,
[data-palette="phpstorm_classic"] select:focus,
[data-palette="phpstorm_classic"] textarea:focus,
[data-palette="phpstorm_teal"] input:focus,
[data-palette="phpstorm_teal"] select:focus,
[data-palette="phpstorm_teal"] textarea:focus {
    background: var(--color-surface) !important;
    border-color: var(--color-primary-bg) !important;
    box-shadow: 0 0 0 3px rgba(130, 170, 255, 0.15);
    outline: none;
}

[data-palette="phpstorm_classic"] h2,
[data-palette="phpstorm_classic"] h3,
[data-palette="phpstorm_classic"] h4,
[data-palette="phpstorm_classic"] td,
[data-palette="phpstorm_classic"] label,
[data-palette="phpstorm_teal"] h2,
[data-palette="phpstorm_teal"] h3,
[data-palette="phpstorm_teal"] h4,
[data-palette="phpstorm_teal"] td,
[data-palette="phpstorm_teal"] label {
    color: var(--color-text);
}

[data-palette="phpstorm_classic"] td,
[data-palette="phpstorm_teal"] td {
    border-bottom: 1px solid var(--color-border) !important;
    border-right:  1px solid var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .logsheet-wrapper td,
[data-palette="phpstorm_teal"] .logsheet-wrapper td {
    border-bottom: 1px solid var(--color-border) !important;
    border-right:  1px solid var(--color-border) !important;
    color: var(--color-text);
}

[data-palette="phpstorm_classic"] .users-table tbody tr:not(:last-child) td,
[data-palette="phpstorm_teal"] .users-table tbody tr:not(:last-child) td {
    border-bottom: 1px solid var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .info-box,
[data-palette="phpstorm_teal"] .info-box {
    background: var(--color-page-bg);
    border-color: var(--color-border);
    color: var(--color-text);
}

[data-palette="phpstorm_classic"] .reportsList,
[data-palette="phpstorm_classic"] .financeList,
[data-palette="phpstorm_classic"] .settingsList,
[data-palette="phpstorm_classic"] .trainingList,
[data-palette="phpstorm_classic"] .myAccountList,
[data-palette="phpstorm_teal"] .reportsList,
[data-palette="phpstorm_teal"] .financeList,
[data-palette="phpstorm_teal"] .settingsList,
[data-palette="phpstorm_teal"] .trainingList,
[data-palette="phpstorm_teal"] .myAccountList {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .reportsItem,
[data-palette="phpstorm_classic"] .financeItem,
[data-palette="phpstorm_classic"] .settingsItem,
[data-palette="phpstorm_classic"] .trainingItem,
[data-palette="phpstorm_classic"] .myAccountItem,
[data-palette="phpstorm_teal"] .reportsItem,
[data-palette="phpstorm_teal"] .financeItem,
[data-palette="phpstorm_teal"] .settingsItem,
[data-palette="phpstorm_teal"] .trainingItem,
[data-palette="phpstorm_teal"] .myAccountItem {
    color: var(--color-text);
}

[data-palette="phpstorm_classic"] .reportsItem:hover,
[data-palette="phpstorm_classic"] .financeItem:hover,
[data-palette="phpstorm_classic"] .settingsItem:hover,
[data-palette="phpstorm_classic"] .trainingItem:hover,
[data-palette="phpstorm_classic"] .myAccountItem:hover,
[data-palette="phpstorm_teal"] .reportsItem:hover,
[data-palette="phpstorm_teal"] .financeItem:hover,
[data-palette="phpstorm_teal"] .settingsItem:hover,
[data-palette="phpstorm_teal"] .trainingItem:hover,
[data-palette="phpstorm_teal"] .myAccountItem:hover {
    background: var(--color-hover);
    color: var(--color-primary-bg);
}

[data-palette="phpstorm_classic"] .defect-banner,
[data-palette="phpstorm_teal"] .defect-banner {
    background: var(--color-surface);
    border-left-color: var(--color-pdf-bg);
}

[data-palette="phpstorm_classic"] .text-muted,
[data-palette="phpstorm_classic"] .users-td-email,
[data-palette="phpstorm_classic"] .defect-banner-meta,
[data-palette="phpstorm_classic"] .defect-notified,
[data-palette="phpstorm_classic"] .invoice-meta-label,
[data-palette="phpstorm_classic"] time,
[data-palette="phpstorm_classic"] small,
[data-palette="phpstorm_classic"] .page-subtitle,
[data-palette="phpstorm_classic"] .color-text-secondary,
[data-palette="phpstorm_classic"] [style*="color: #"],
[data-palette="phpstorm_teal"] .text-muted,
[data-palette="phpstorm_teal"] .users-td-email,
[data-palette="phpstorm_teal"] .defect-banner-meta,
[data-palette="phpstorm_teal"] .defect-notified,
[data-palette="phpstorm_teal"] .invoice-meta-label,
[data-palette="phpstorm_teal"] time,
[data-palette="phpstorm_teal"] small,
[data-palette="phpstorm_teal"] .page-subtitle,
[data-palette="phpstorm_teal"] .color-text-secondary {
    color: var(--color-text-secondary) !important;
}

[data-palette="phpstorm_classic"] .role-yes,
[data-palette="phpstorm_teal"] .role-yes {
    background:   var(--color-success-bg) !important;
    color:        var(--color-success-text) !important;
    border-color: var(--color-success-border) !important;
}

[data-palette="phpstorm_classic"] .btn-complete,
[data-palette="phpstorm_teal"] .btn-complete {
    background:   #6ee7b7 !important;
    color:        #022c22 !important;
    border-color: #34d399 !important;
}

[data-palette="phpstorm_classic"] .users-table tbody tr:hover td,
[data-palette="phpstorm_teal"] .users-table tbody tr:hover td,
[data-palette="phpstorm_classic"] .logsheet-wrapper tbody tr:hover td,
[data-palette="phpstorm_teal"] .logsheet-wrapper tbody tr:hover td {
    background: var(--color-hover);
}

[data-palette="phpstorm_classic"] .calendar-day-cell,
[data-palette="phpstorm_teal"] .calendar-day-cell {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .calendar-day-cell:hover,
[data-palette="phpstorm_teal"] .calendar-day-cell:hover {
    background: var(--color-hover);
}

/* --- Dark: force all table rows dark --- */
[data-palette="phpstorm_classic"] tr,
[data-palette="phpstorm_classic"] td,
[data-palette="phpstorm_teal"] tr,
[data-palette="phpstorm_teal"] td {
    background-color: var(--color-surface) !important;
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] tbody tr:nth-child(even) td,
[data-palette="phpstorm_teal"] tbody tr:nth-child(even) td {
    background-color: var(--color-bg-subtle) !important;
}

[data-palette="phpstorm_classic"] tbody tr:hover td,
[data-palette="phpstorm_teal"] tbody tr:hover td {
    background-color: var(--color-hover) !important;
}

/* --- Dark: booked-out row override --- */
[data-palette="phpstorm_classic"] tbody tr.flight-row--booked-out td,
[data-palette="phpstorm_teal"] tbody tr.flight-row--booked-out td {
    background-color: var(--color-booked-out-bg) !important;
}
[data-palette="phpstorm_classic"] tbody tr.flight-row--booked-out:hover td,
[data-palette="phpstorm_teal"] tbody tr.flight-row--booked-out:hover td {
    background-color: var(--color-booked-out-hover) !important;
}

/* --- Dark: defect level colours --- */
[data-palette="phpstorm_classic"] .level-select.level-red,
[data-palette="phpstorm_classic"] td.level-red {
    background-color: #f07a30 !important;
    color:            #ffffff !important;
    border-color:     #b85010 !important;
}

[data-palette="phpstorm_teal"] .level-select.level-red,
[data-palette="phpstorm_teal"] td.level-red {
    background-color: #ff5572 !important;
    color:            #ffffff !important;
    border-color:     #cc2244 !important;
}

[data-palette="phpstorm_classic"] .level-select.level-amber,
[data-palette="phpstorm_classic"] td.level-amber,
[data-palette="phpstorm_teal"] .level-select.level-amber,
[data-palette="phpstorm_teal"] td.level-amber {
    background-color: #ffd866 !important;
    color:            #2a1800 !important;
    border-color:     #c8a000 !important;
}

[data-palette="phpstorm_classic"] .level-select.level-green,
[data-palette="phpstorm_classic"] td.level-green,
[data-palette="phpstorm_teal"] .level-select.level-green,
[data-palette="phpstorm_teal"] td.level-green {
    background-color: #6ee7b7 !important;
    color:            #022c22 !important;
    border-color:     #34d399 !important;
}

/* --- Dark: defect banner badges --- */
[data-palette="phpstorm_classic"] .defect-banner-badge--red {
    background: #f07a30 !important;
    color:      #ffffff !important;
    border-color: #b85010 !important;
}

[data-palette="phpstorm_teal"] .defect-banner-badge--red {
    background: #ff5572 !important;
    color:      #ffffff !important;
    border-color: #cc2244 !important;
}

[data-palette="phpstorm_classic"] .defect-banner-badge--amber,
[data-palette="phpstorm_teal"] .defect-banner-badge--amber {
    background: #ffd866 !important;
    color:      #2a1800 !important;
    border-color: #c8a000 !important;
}

[data-palette="phpstorm_classic"] .defect-banner-badge--green,
[data-palette="phpstorm_teal"] .defect-banner-badge--green {
    background: #6ee7b7 !important;
    color:      #022c22 !important;
    border-color: #34d399 !important;
}

/* --- Dark: defect banner visibility --- */
[data-palette="phpstorm_classic"] .defect-banner-title,
[data-palette="phpstorm_teal"] .defect-banner-title {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .defect-banner,
[data-palette="phpstorm_teal"] .defect-banner {
    background: var(--color-surface) !important;
    border-left-color: #ffd866 !important;
}

[data-palette="phpstorm_classic"] .defect-banner--red {
    border-left-color: #f07a30 !important;
    background: #1e1a2a !important;
}

[data-palette="phpstorm_teal"] .defect-banner--red {
    border-left-color: #ff5572 !important;
    background: #1e1a2a !important;
}

[data-palette="phpstorm_classic"] .defect-banner--green,
[data-palette="phpstorm_teal"] .defect-banner--green {
    border-left-color: #6ee7b7 !important;
    background: #0f1e1a !important;
}

[data-palette="phpstorm_classic"] .defect-banner-item,
[data-palette="phpstorm_teal"] .defect-banner-item {
    background: rgba(255, 255, 255, 0.05) !important;
}

[data-palette="phpstorm_classic"] .defect-banner-desc,
[data-palette="phpstorm_teal"] .defect-banner-desc {
    color: var(--color-text) !important;
}

/* --- Dark: filter form and date inputs --- */
[data-palette="phpstorm_classic"] .filter-form,
[data-palette="phpstorm_teal"] .filter-form {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .filter-form select,
[data-palette="phpstorm_classic"] .filter-form input,
[data-palette="phpstorm_teal"] .filter-form select,
[data-palette="phpstorm_teal"] .filter-form input {
    background: var(--color-page-bg) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

/* --- Dark: billing column tints --- */
[data-palette="phpstorm_classic"] .billing-col-flight,
[data-palette="phpstorm_teal"] .billing-col-flight {
    background: rgba(130, 170, 255, 0.12) !important;
    color: #93b4e8 !important;
}

[data-palette="phpstorm_classic"] .billing-td-flight,
[data-palette="phpstorm_teal"] .billing-td-flight {
    background: rgba(130, 170, 255, 0.06) !important;
}

[data-palette="phpstorm_classic"] .billing-col-taxi,
[data-palette="phpstorm_teal"] .billing-col-taxi {
    background: rgba(255, 216, 102, 0.12) !important;
    color: #c9a84c !important;
}

[data-palette="phpstorm_classic"] .billing-td-taxi,
[data-palette="phpstorm_teal"] .billing-td-taxi {
    background: rgba(255, 216, 102, 0.06) !important;
}

[data-palette="phpstorm_classic"] .billing-col-cfi,
[data-palette="phpstorm_teal"] .billing-col-cfi {
    background: rgba(195, 232, 141, 0.12) !important;
}

[data-palette="phpstorm_classic"] .billing-td-cfi,
[data-palette="phpstorm_teal"] .billing-td-cfi {
    background: rgba(195, 232, 141, 0.06) !important;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background-color: #f4f6f8;
    margin: 0;
    padding: 20px;
    padding-top: 0;
    overflow-x: hidden;
}

/* --- Shared page container --- */
.container {
    max-width: var(--page-max-width);
    margin: 20px auto;
    background: #fff;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    overflow: hidden;
}

h2, h3 {
    color: #333;
}

h2 {
    text-align: left;
}

.logsheet-title {
    text-align: center;
}

.tabs {
    margin-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-bottom: 2px solid var(--color-border, #e5e7eb);
}

.tabs button,
.tab-button {
    padding: 10px 20px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-secondary, #6b7280);
    transition: color 0.15s, border-color 0.15s;
    font-family: inherit;
    text-decoration: none;
}

.tabs button:hover,
.tab-button:hover {
    color: var(--color-text, #1e293b);
}

.tabs button.active,
.tab-button.active {
    color: var(--color-primary-bg, #0072ce);
    border-bottom-color: var(--color-primary-bg, #0072ce);
}

.tab {
    display: none;
}

.tab.active {
    display: block;
}

.info-grid {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 20px;
    gap: 8px;
}

.info-box {
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 10px 12px;
    font-size: 14px;
    flex-grow: 1;
    background: var(--color-bg-subtle);
}

.info-box label {
    display: block;
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--color-text-secondary);
    margin-bottom: 4px;
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

th, td {
    border: 1px solid #ccc;
    padding: 8px 10px;
    text-align: left;
}

td {
    color: var(--color-text);
}

th {
    background: var(--color-th-bg);
    color: var(--color-th-text);
    border-bottom: 1px solid var(--color-th-border);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    padding: 10px 10px;
}

th[colspan] {
    text-align: center;
}

.critical {
    color: #dc2626;
    font-weight: 700;
    background: #fef2f2;
    padding: 2px 8px;
    border-radius: 4px;
}

.critical-warning {
    background: var(--color-danger-bg);
    color: var(--color-danger-text);
    font-weight: 600;
    padding: 12px 16px;
    text-align: center;
    border: 1px solid var(--color-danger-border);
    border-radius: 10px;
    margin-bottom: 8px;
    box-shadow: 0 1px 4px rgba(220, 53, 69, 0.08);
}
.defect-banner {
    border-left: 4px solid #f59e0b;
    background: #fef3c7;
    border-radius: 0 8px 8px 0;
    padding: 14px 18px;
    margin-bottom: 10px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.defect-banner--red {
    border-left-color: #dc2626;
    background: var(--color-danger-bg);
}
.defect-banner--amber {
    border-left-color: #f59e0b;
}
.defect-banner--green {
    border-left-color: #059669;
    background: var(--color-pdf-bg);
}
.defect-banner-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}
.defect-banner-icon {
    font-size: 18px;
    line-height: 1;
}
.defect-banner-title {
    font-weight: 700;
    font-size: 14px;
    color: #1a1a1a;
}
.defect-banner-count {
    font-size: 12px;
    color: #666;
    margin-left: auto;
    font-weight: 500;
}
.defect-banner-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.defect-banner-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 10px;
    background: rgba(255,255,255,0.7);
    border-radius: 5px;
    font-size: 13px;
}
.defect-banner-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}
.defect-banner-badge--red {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}
.defect-banner-badge--amber {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}
.defect-banner-badge--green {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}
.defect-banner-desc {
    color: #222;
    font-weight: 500;
}
.defect-banner-meta {
    color: #888;
    font-size: 11px;
    margin-left: auto;
    white-space: nowrap;
}
.defect-flight-tag {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    padding: 2px 6px;
    background: #fef9ee;
    border: 1px solid #f0e0c0;
    border-radius: 4px;
    margin-bottom: 3px;
    line-height: 1.3;
}
.defect-flight-tag-desc {
    color: #333;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 120px;
}
/* --- Inline action links inside table cells --- */
.add-defect-link {
    background:      none;
    border:          none;
    color:           var(--color-primary-border);
    font-size:       12px;
    font-weight:     500;
    text-decoration: none;
    white-space:     nowrap;
    cursor:          pointer;
    padding:         0;
}

.add-defect-link:hover {
    background:      transparent !important;
    color:           var(--color-primary-border);
    box-shadow:      none;
    text-decoration: underline;
    text-shadow:     0 0 6px rgba(0, 0, 0, 0.25);
}

.link-assign-people,
.link-add-flag {
    background: none;
    border: none;
    color: var(--color-primary-border);
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    padding: 0;
}

.link-assign-people:hover,
.link-add-flag:hover {
    background:  transparent !important;
    color:       var(--color-primary-border);
    box-shadow:  none;
    text-decoration: underline;
    text-shadow:     0 0 6px rgba(0, 0, 0, 0.25);
}

.filter-toggle {
    display: none;
}

.filter-body {
    display: contents;
}

.filter-form {
    margin-top: 16px;
    margin-bottom: 24px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-card);
    padding: 20px 24px;
    box-shadow: var(--shadow-card);
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 16px;
}

.filter-form label {
    display: flex;
    flex-direction: column;
    color: var(--color-text-secondary);
    font-weight: 600;
    font-size: 13px;
    gap: 4px;
}

.filter-form select,
.filter-form input {
    height: 38px;
    padding: 0 12px;
    border: 1px solid #d1d5db;
    border-radius: var(--radius-sm);
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
}

.filter-form .button-group {
    align-self: flex-end;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
}

.filter-form .button-group .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0;
    height: 32px;
    padding: 0 10px;
    font-size: 12px;
    white-space: nowrap;
    border: 1px solid #d1d5db;
    border-radius: var(--radius-sm);
    box-sizing: border-box;
    font-family: inherit;
}

.filter-form select,
.filter-form input {
    width: 100%;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.filter-form select:focus,
.filter-form input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 114, 206, 0.1);
}

.filter-checkbox {
    flex-direction: row !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-secondary);
    cursor: pointer;
    white-space: nowrap;
    align-self: center;
}

.filter-checkbox input[type="checkbox"] {
    width: auto;
    height: auto;
    margin: 0;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.billing-col-group {
    text-align: center !important;
    border-bottom: 1px solid #d1d5db;
    color: var(--color-th-text);
}

.billing-sub-th {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 6px 10px !important;
    color: inherit;
}

/* Invoice links in billing table */
.users-table td a[href*="invoice"] {
    color: var(--color-primary);
    opacity: 1;
}

/* Flight columns — blue tint */
.billing-col-flight {
    background: #eff6ff !important;
    color: #1e40af !important;
}
.billing-td-flight { background: #f8fbff; }

/* Taxi columns — amber tint */
.billing-col-taxi {
    background: #fefce8 !important;
    color: #854d0e !important;
}
.billing-td-taxi { background: #fffef5; }

/* CFI columns — green tint */
.billing-col-cfi {
    background: #f0fdf4 !important;
    color: #166534 !important;
}
.billing-td-cfi { background: #f8fdf9; }

.users-table tbody tr:hover .billing-td-flight,
.users-table tbody tr:hover .billing-td-taxi,
.users-table tbody tr:hover .billing-td-cfi {
    background: #f0f7ff;
}

.maintenance-summary {
    margin-bottom: 24px;
}

.maintenance-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-top: 16px;
}
.maintenance-scroll table {
    min-width: 500px;
    width: 100%;
}
.maintenance-scroll th {
    white-space: nowrap;
}

.maintenance-title-row th {
    background: var(--color-th-bg);
    color: var(--color-th-text);
    font-weight: 600;
    text-transform: none;
    letter-spacing: 0;
    font-size: 13px;
    border-bottom: 2px solid var(--color-th-border);
}

/* Global bold text color */
strong, .bold-label {
    color: var(--color-text);
    font-weight: bold;
}

/* Logsheet page title — keep centred despite global h2 being left-aligned */
.logsheet-title {
    color: var(--color-text);
    margin-top: 0;
}

.logsheet-wrapper {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-card);
    padding: 24px;
    background-color: #fff;
    margin-top: 20px;
    box-shadow: var(--shadow-card);
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.pilot-input {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
}

table th.pilot,
table td.pilot {
    width: 180px;
}

table th.initials,
table td.initials {
    width: 60px;
}

table th.tiny,
table td.tiny {
    width: 50px;
}

th.pilot, td.pilot {
    width: 180px;
}

th.initials, td.initials {
    width: 60px;
}

th.tiny, td.tiny {
    width: 50px;
}

.airplane-icon {
    display: inline-block;
    margin-left: 6px;
    animation: fly 1s linear infinite;
}

@keyframes fly {
    0% { transform: translateX(0); opacity: 1; }
    100% { transform: translateX(10px); opacity: 0.2; }
}

.flash-success {
    animation: flashGreen 0.8s ease;
}

@keyframes flashGreen {
    0%   { background-color: #d4edda; }
    100% { background-color: transparent; }
}

.highlight {
    background-color: #d4edda;
    transition: background-color 1s ease;
}
.spinner {
    animation: spin 1s infinite linear;
    display: inline-block;
}
@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* === Page-load spinner === */
.page-loader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-page-bg, #ffffff);
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.page-loader--done {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}
.page-loader-spinner {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 3px solid var(--color-border, #e5e7eb);
    border-top-color: var(--color-primary, #0072ce);
    animation: spin 0.7s linear infinite;
}

@keyframes tileSaved {
    0%   { outline: 3px solid #6ee7b7; outline-offset: 0; }
    50%  { outline: 3px solid #6ee7b7; outline-offset: 0; }
    100% { outline: 3px solid transparent; outline-offset: 0; }
}

.tile-saved {
    animation: tileSaved 2s ease-out forwards;
}

@keyframes cellSaved {
    0%   { outline: 3px solid #6ee7b7; outline-offset: -3px; background-color: rgba(110, 231, 183, 0.15); }
    50%  { outline: 3px solid #6ee7b7; outline-offset: -3px; background-color: rgba(110, 231, 183, 0.08); }
    100% { outline: 3px solid transparent; outline-offset: -3px; background-color: transparent; }
}

td.cell-saved {
    animation: cellSaved 2s ease-out forwards;
}

@keyframes tileError {
    0%   { outline: 3px solid #ff5572; outline-offset: 0; }
    100% { outline: 3px solid transparent; outline-offset: 0; }
}

.tile-error {
    animation: tileError 1s ease-out forwards;
}

/* <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<><<<<< AUTH PAGES (login / set-password) <<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> */
body.auth-body {
    background: #f4f6f8;
    padding: 0;
    min-height: 100dvh;
}

.auth-page {
    min-height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.auth-card {
    width: 100%;
    max-width: 420px;
    background-color: #fdfcfd;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-card);
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(0, 0, 0, 0.04);
    padding: 36px 32px 32px;
    text-align: center;
}

.auth-title {
    margin: 0 0 6px;
    font-size: 22px;
    font-weight: 700;
    color: var(--color-text);
}

.auth-subtitle {
    margin: 0 0 20px;
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.5;
}

.auth-alert {
    background: #fff4f4;
    border: 1px solid #f5c2c7;
    color: #7f1d1d;
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    margin: 0 0 16px;
    font-size: 14px;
    text-align: left;
}

.auth-form .form-row {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-bottom: 16px;
    text-align: left;
}

.auth-form label {
    font-weight: 600;
    font-size: 13px;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.input {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 11px 14px;
    outline: none;
    font-size: 15px;
    background: var(--color-bg-subtle);
    width: 100%;
    transition: border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base);
    box-sizing: border-box;
}

.input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 114, 206, .12);
    background: #fff;
}

.actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    margin-top: 20px;
}

/* === APP-WIDE BUTTON SYSTEM === */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 14px;
    font-size: var(--font-btn);
    font-family: inherit;
    font-weight: var(--font-weight-btn);
    text-decoration: none;
    border-radius: var(--radius-btn);
    border: 1px solid transparent;
    cursor: pointer;
    line-height: 1.5;
    white-space: nowrap;
    transition: box-shadow var(--transition-base);
    box-shadow: none;
}

.btn:hover {
    box-shadow: var(--shadow-btn-hover);
}

/* Positive action — Filter, Generate, Create, Add, Save, Submit, Book */
.btn-primary {
    background: var(--color-primary-bg);
    color: var(--color-primary-text);
    border-color: var(--color-primary-border);
}

/* Negative action — Delete, Remove, Cancel */
.btn-danger {
    background: var(--color-danger-bg);
    color: var(--color-danger-text);
    border-color: var(--color-danger-border);
}

/* Neutral — filter shortcuts, secondary nav */
.btn-secondary {
    background: var(--color-neutral-bg);
    color: var(--color-neutral-text);
    border-color: var(--color-neutral-border);
}

/* PDF — unique action, stands alone */
.btn-pdf {
    background: var(--color-pdf-bg);
    color: var(--color-pdf-text);
    border-color: var(--color-pdf-border);
}

/* Outline only — Book Out, Sign A-check ONLY */
.btn-outline {
    background: var(--color-outline-bg);
    color: var(--color-outline-text);
    border-color: var(--color-outline-border);
}

/* Complete — positive terminal state (e.g. Mark complete) */
.btn-complete {
    background:   #d1fae5;
    color:        #065f46;
    border-color: #6ee7b7;
}

.link-muted {
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 13px;
    transition: color var(--transition-base);
}

.link-muted:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.auth-page { align-items: flex-start; }
.auth-card { margin-top: 8vh; }

.auth-weather-link {
    display: block;
    margin-bottom: 20px;
    padding: 10px;
    font-size: 14px;
    font-weight: 700;
    border-radius: 8px;
    text-decoration: none;
    text-align: center;
    letter-spacing: 0.02em;
    background: linear-gradient(135deg, #0ea5e9, #22d3ee);
    color: #082f49;
    border-color: #0891b2;
    box-shadow: 0 0 8px rgba(34, 211, 238, 0.25);
}

.auth-weather-link:hover {
    box-shadow: 0 0 14px rgba(34, 211, 238, 0.4);
}

.auth-form .btn-primary {
    width: 100%;
    padding: 10px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 8px;
    letter-spacing: 0.02em;
}

.auth-form .hint {
    color: var(--color-text-secondary);
    font-size: 12px;
    margin-top: 2px;
}

/* A-check time input — compact and neat */
.acheck-time-input {
    width: 150px;              /* fits HH:MM + clock icon nicely */
    min-width: 72px;
    max-width: 90px;
    padding: 2px 4px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box;
}
/* Landing cell: pin edit icon so it doesn't jump */
.landing-cell {
    position: relative;
    padding-right: 18px !important;
    white-space: nowrap;
}

.landing-cell .e-icon-link {
    position: absolute;
    right: 1px;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 0;
}

.landing-input {
    width: 30px;
}
.defect-input {
    width: 150px;
}

/* remove blue halo / glow when focused */
.acheck-time-input:focus {
    outline: none;
    border-color: #777;
    box-shadow: none;
}

/* ================================================================
   SHARED MODAL BASE
   ================================================================ */
.modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    padding: 16px;
}

.modal-panel {
    background: #fff;
    border-radius: var(--radius-card);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
    width: 560px;
    max-width: 100%;
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    padding: 20px;
    box-sizing: border-box;
    animation: modalSlideIn 0.2s ease-out;
}

@keyframes modalSlideIn {
    from { opacity: 0; transform: translateY(-12px); }
    to   { opacity: 1; transform: translateY(0); }
}

.modal-title {
    margin: 0 0 14px 0;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 0.2px;
    color: var(--color-primary);
}

.modal-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 14px;
}

.modal-label {
    display: block;
    font-weight: 600;
    margin-bottom: 4px;
    font-size: 14px;
    color: var(--color-text);
}

.modal-label + .modal-label {
    margin-top: 12px;
}

.modal-input {
    width: 100%;
    padding: 8px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
}

.modal-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 114, 206, 0.15);
}

textarea.modal-input {
    resize: vertical;
}

/* Modal button variants removed — use .btn-danger and .btn-primary instead */

/* --- Defect level buttons --- */
.defect-levels {
    display: flex;
    gap: 8px;
    margin-top: 6px;
}

.btn-level {
    flex: 1;
    font-weight: bold;
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    cursor: pointer;
    transition: all var(--transition-base);
}

.btn-level-critical {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

.btn-level-critical:hover {
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

.btn-level-warning {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}

.btn-level-warning:hover {
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

.btn-level-mild {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}

.btn-level-mild:hover {
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

/* --- Utility classes --- */
.text-muted { color: #6b7280; font-weight: 400; }
.text-success { color: #1e7e34; }

/* ================================================================
   A-CHECK — SPECIFIC STYLES (canvas, trigger button, display)
   ================================================================ */
.acheck-sig-pad {
    border: 2px dashed #cbd5e1;
    border-radius: 10px;
    background: #f8fafc;
    touch-action: none;
}

/* acheck-btn replaced by .btn .btn-outline in HTML */

.acheck-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
}

.acheck-line {
    font-size: 13px;
    color: #0f172a;
    white-space: nowrap;
}

.acheck-sig img {
    display: block;
    background: #fff;
    max-height: 38px;
    max-width: 220px;
    padding: 2px;
}

.acheck-box {
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

#aCheckSectionSigned {
    padding-left: 30px;
}

/* ================================================================
   PEOPLE MODAL — SPECIFIC STYLES
   ================================================================ */
.people-checkbox-list {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg-subtle);
    margin-bottom: 14px;
    -webkit-overflow-scrolling: touch;
}

.people-checkbox-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    border-bottom: 1px solid var(--color-border);
    transition: background var(--transition-base);
    user-select: none;
}

.people-checkbox-item:last-child {
    border-bottom: none;
}

.people-checkbox-item:hover {
    background: var(--color-hover);
}

.people-checkbox-item:has(input:checked) {
    background: var(--color-primary-bg);
}

.people-checkbox-input {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary-border);
    cursor: pointer;
    flex-shrink: 0;
    margin: 0;
}

.people-checkbox-name {
    font-size: 14px;
    color: var(--color-text);
    line-height: 1.4;
}

.people-checkbox-item:has(input:checked) .people-checkbox-name {
    font-weight: 600;
    color: var(--color-primary-text);
}

.people-free {
    margin-top: 10px;
}

.people-free .modal-input {
    width: 100%;
    margin-bottom: 10px;
}

.people-label {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
    font-size: 14px;
    color: var(--color-text);
}

.people-save-user {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: #334155;
    margin-top: 4px;
    margin-bottom: 18px;
    user-select: none;
}

.people-save-user input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #f4f6f8;
    border-bottom: 1px solid #ccc;
    padding: 8px 16px;
    font-family: sans-serif;
    position: sticky;
    top: 0;
    z-index: 100;
}
.topbar-left {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}
.topbar-logo {
    display: flex;
    align-items: center;
    margin-right: 4px;
}
.topbar-logo-img {
    height: 38px;
    width: 38px;
    border-radius: 6px;
    object-fit: contain;
}
.topbar-org-logo {
    height: 32px;
    max-width: 100px;
    object-fit: contain;
    margin-right: 8px;
}
.topbar-left .btn {
    margin: 0;
    padding: 5px 10px;
    font-size: 12px;
    white-space: nowrap;
}

.topbar-right {
    display: flex;
    align-items: center;
    gap: 10px;
}
.topbar-right .btn {
    margin: 0;
    padding: 5px 10px;
    font-size: 12px;
    white-space: nowrap;
}

/* Logout link — uses outline style */
.logout-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 10px;
    font-size: var(--font-btn);
    font-family: inherit;
    font-weight: var(--font-weight-btn);
    text-decoration: none;
    border-radius: var(--radius-btn);
    border: 1px solid var(--color-outline-border);
    background: var(--color-outline-bg);
    color: var(--color-outline-text);
    cursor: pointer;
    line-height: 1.5;
    white-space: nowrap;
    transition: box-shadow var(--transition-base);
    box-shadow: none;
}
.logout-link:hover {
    box-shadow: var(--shadow-btn-hover);
}

/* --- Topbar org badge & user --- */
.topbar-org-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #eef2ff;
    border: 1px solid #c7d2fe;
    border-radius: 8px;
    padding: 4px 10px 4px 12px;
}

.topbar-org-name {
    font-weight: 600;
    font-size: 13px;
    color: #3730a3;
}

.topbar-org-switch {
    font-size: 12px;
    font-weight: 500;
    color: #6366f1;
    text-decoration: none;
    padding: 2px 8px;
    border-radius: 4px;
    transition: background 0.15s;
}

.topbar-org-switch:hover {
    background: rgba(99, 102, 241, 0.1);
    text-decoration: none;
}

.topbar-divider {
    width: 1px;
    height: 20px;
    background: #d1d5db;
    margin: 0 4px;
}

.topbar-user {
    font-size: 13px;
    color: var(--color-text-secondary);
    font-weight: 500;
}

/* Gray out settings buttons if not admin */
.btn.disabled-hint {
    opacity: 0.5;
    cursor: not-allowed;
    position: relative;
}

/* make link visually disabled but allow hover events */
.btn.disabled-hint:not([href]) {
    pointer-events: auto;
}
.btn.disabled-hint[href] {
    pointer-events: auto;
}
.btn.disabled-hint::after {
    content: 'Only Administrator can see settings.';
    position: absolute;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.85);
    color: #fff;
    font-size: 12px;
    padding: 4px 8px;
    border-radius: 4px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease-in-out;
    z-index: 10;
}

.btn.disabled-hint:hover::after {
    opacity: 1;
}

/* ═══════════════════════════════════════════════
   NAV ACTIVE STATE — single unified rule
   ═══════════════════════════════════════════════ */
.nav-active {
    background:   var(--color-primary-border) !important;
    color:        #ffffff !important;
    border-color: var(--color-primary-border) !important;
    font-weight:  600;
}

/* ═══════════════════════════════════════════════
   TOPBAR NAVIGATION BUTTONS — GROUP A (identity colours)
   ═══════════════════════════════════════════════ */

/* Techlog — the home anchor, slate blue */
.btn-nav-techlog {
    background: #e8edf5;
    color: #1e3a5f;
    border-color: #b0c4de;
}
.btn-nav-techlog.nav-active {
    cursor: default;
    pointer-events: none;
}

/* Bookings — distinguishable purple */
.btn-nav-bookings {
    background:   #7c3aed;
    color:        #ffffff;
    border-color: #5b21b6;
}
.btn-nav-bookings.nav-active {
    cursor: default;
    pointer-events: none;
}

/* Defects — always has a pink/rose tint to signal risk */
.btn-nav-defects {
    background: var(--color-danger-bg);
    color: var(--color-danger-text);
    border-color: var(--color-danger-border);
}
.btn-nav-defects.nav-active {
    cursor: default;
    pointer-events: none;
}

/* Weather — teal gradient to match the dashboard */
.btn-nav-weather {
    background: linear-gradient(135deg, #0ea5e9, #22d3ee);
    color: #082f49;
    border-color: #0891b2;
    font-weight: 700;
    box-shadow: 0 0 8px rgba(34, 211, 238, 0.25);
}
.btn-nav-weather:hover {
    box-shadow: 0 0 14px rgba(34, 211, 238, 0.4);
}
.btn-nav-weather.nav-active {
    cursor: default;
    pointer-events: none;
}

/* <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>><<<<<<< REPORTS <<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> */


/*.reports-container {*/
/*    max-width: 1080px;*/
/*    margin: 0 auto;*/
/*    padding: 12px 16px 28px;*/
/*}*/

/*.reports-title {*/
/*    text-align: center;*/
/*    margin: 10px 0 22px;*/
/*}*/

/*.form-inline.reports-filters {*/
/*    display: flex;*/
/*    flex-wrap: wrap;*/
/*    align-items: flex-end;*/
/*    justify-content: flex-start;*/
/*    gap: 18px;*/
/*    margin: 16px 0 22px;*/
/*}*/

/* Layout */
.reports-container {
    max-width: 960px;
    margin: 0 auto;
    padding: 10px 12px 18px;
}
.reports-title {
    font-size: 26px;
    line-height: 1.2;
    text-align: center;
    margin: 6px 0 12px;
}

/* Filters row */
.form-inline.reports-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 10px 12px;                  /* row-gap, column-gap */
    margin: 8px 0 12px;
}
.reports-filters .form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1 1 220px;
    min-width: 220px;
    max-width: 280px;
}
.reports-filters .form-group label {
    font-weight: 500;
    font-size: 14px;
    color: #444;
    margin: 0;
}
.reports-filters .input,
.reports-filters select,
.reports-filters input[type="date"] {
    height: 38px;
    padding: 6px 10px;
    font-size: 15px;
    border: 1px solid #ccc;
    border-radius: 6px;
    width: 100%;
    box-sizing: border-box;
}
.reports-filters button.btn {
    align-self: flex-start;
    min-width: 150px;
    height: 38px;
    font-size: 15px;
}

/* Back link + summary */
.back-button { margin-bottom: 10px; display: inline-block; }
.reports-summary {
    margin: 8px 0 14px;
    padding: 10px 12px;
    border-radius: 10px;
    background: #f7f9fc;
    font-size: 15px;
}

/* Results table */
.reports-table.table { width: 100%; border-collapse: collapse; }
.reports-table.table th,
.reports-table.table td {
    padding: 8px 10px;
    border-bottom: 1px solid #e6e6e6;
    text-align: left;
}
.reports-table.table thead th { background: var(--color-th-bg); color: var(--color-th-text); border-bottom: 1px solid var(--color-th-border); font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; font-size: 12px; }
.reports-table.table tfoot td { font-weight: 700; background: #fafbff; }

/* Dropdown trigger lives near other header buttons; don't clip */
.button-group {
    overflow: visible;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    align-self: flex-end;
}

/* === Shared topbar dropdown trigger button (GROUP B — neutral) === */
.topbar-dropdown-btn {
    background: var(--color-neutral-bg);
    color: var(--color-neutral-text);
    border: 1px solid var(--color-neutral-border);
    font-family: inherit;
    font-size: 13px;
    font-weight: var(--font-weight-btn);
    letter-spacing: 0.01em;
}
.topbar-dropdown-btn:hover,
.topbar-dropdown-btn:focus {
    box-shadow: var(--shadow-btn-hover);
}
.topbar-dropdown-btn.nav-active {
    pointer-events: auto;
    cursor: pointer;
}

/* === Shared topbar dropdown menu/panel === */
.reportsMenu,
.financeMenu,
.settingsMenu,
.trainingMenu,
.myAccountMenu { position: relative; display: inline-block; vertical-align: middle; }

.reportsList,
.financeList,
.settingsList,
.trainingList,
.myAccountList {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    padding: 6px 0;
    z-index: 1000;
}

.reportsMenu:hover .reportsList,
.reportsMenu:focus-within .reportsList,
.financeMenu:hover .financeList,
.financeMenu:focus-within .financeList,
.settingsMenu:hover .settingsList,
.settingsMenu:focus-within .settingsList,
.trainingMenu:hover .trainingList,
.trainingMenu:focus-within .trainingList,
.myAccountMenu:hover .myAccountList,
.myAccountMenu:focus-within .myAccountList {
    display: block;
}

/* === Shared dropdown items === */
.reportsItem,
.financeItem,
.settingsItem,
.trainingItem,
.myAccountItem {
    display: block;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 500;
    color: #334155;
    text-decoration: none;
    transition: background 0.12s, color 0.12s;
}
.reportsItem:hover,
.financeItem:hover,
.settingsItem:hover,
.trainingItem:hover,
.myAccountItem:hover {
    background: #f1f5f9;
    color: #0f172a;
}
/* My Account dropdown opens right-aligned to avoid overflow */
.myAccountMenu .myAccountList {
    left: auto;
    right: 0;
}

.myAccountItem.disabled-item {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
    color: #94a3b8;
}

.breaksTime {
    background: lightgray;
}

/* ===== Mobile tightening ===== */
@media (max-width: 720px) {
    .reports-container { padding: 8px 10px 14px; }
    .reports-title { font-size: 22px; margin: 4px 0 10px; }
    .form-inline.reports-filters {
        flex-direction: column;
        align-items: stretch;
        gap: 8px 10px;
        margin: 6px 0 10px;
    }
    .reports-filters .form-group { max-width: 100%; min-width: unset; }
    .reports-filters .input,
    .reports-filters select,
    .reports-filters input[type="date"] { height: 34px; font-size: 13px; }
    .reports-filters button.btn { width: 100%; align-self: stretch; min-height: 34px; }
    .back-button.btn { padding: 7px 10px; font-size: 13px; }
}

/* <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>><<<<<<< QUICK EDITS <<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> */
.e-icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 6px;
    width: 18px;
    height: 18px;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    opacity: 0.55;
    color: #555;
    transition: color 0.15s ease, opacity 0.15s ease;
}

td .e-icon-link:hover,
td .e-icon-link:focus,
td .e-icon-link:active,
.e-icon-link:hover,
.e-icon-link:focus,
.e-icon-link:active {
    background:        none !important;
    background-color:  transparent !important;
    border:            none !important;
    box-shadow:        none !important;
    color:             var(--color-primary-border);
    opacity:           1;
    outline:           none;
}

[data-palette="phpstorm_classic"] .e-icon-link,
[data-palette="phpstorm_teal"] .e-icon-link {
    color:   #8892a8;
    opacity: 0.9;
}

[data-palette="phpstorm_classic"] .e-icon-link:hover,
[data-palette="phpstorm_teal"] .e-icon-link:hover {
    background:  transparent !important;
    color:       var(--color-primary-bg);
    opacity:     1;
    box-shadow:  none !important;
}

/* Icon itself */
.e-icon-link__icon {
    display: inline-block;
    width: 14px;
    height: 14px;
    fill: currentColor;
    vertical-align: middle;
    pointer-events: none;
}

/* --- Inline-edit layout: anchor the pencil icon --- */
.pic-line {
    display: flex;
    align-items: center;
    gap: 2px;
}

.pic-line .e-icon-link {
    flex-shrink: 0;
    order: 2;
    margin-left: 0;
}

.pic-line .pic-display,
.pic-line .pic-select {
    order: 1;
    min-width: 0;
}

.pic-line .pic-select {
    max-width: 140px;
}

/* A-check time: pin edit icon so it doesn't jump */
.info-box:has(.acheck-time-display) {
    position: relative;
    padding-right: 20px;
}

.info-box .acheck-time-display,
.info-box .acheck-time-input {
    vertical-align: middle;
}

.info-box:has(.acheck-time-display) .e-icon-link {
    position: absolute;
    right: 4px;
    bottom: 6px;
    margin-left: 0;
}

/* Uplift section — compact single row */
.uplift-section {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 10px 16px;
    margin-top: 10px;
    border: 1px solid var(--color-border);
    border-radius: 10px;
    font-size: 13px;
    background: var(--color-bg-subtle);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.uplift-title {
    font-weight: 700;
    color: var(--color-text);
    white-space: nowrap;
}

.uplift-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
}

.uplift-label {
    color: var(--color-text-secondary, #666);
    font-weight: 500;
}

.uplift-display {
    font-weight: 600;
    color: var(--color-text);
}

.uplift-item .uplift-input {
    width: 60px;
    padding: 1px 4px;
    font-size: 13px;
    border: 1px solid var(--color-primary);
    border-radius: 4px;
}

.uplift-item .e-icon-link {
    margin-left: 0;
}

.not-flown-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    background: lightpink;      /* soft amber */
    color: red;           /* readable on amber */
    border: 1px solid #f0e1a6;
    vertical-align: baseline;
}


/* ////////////////////////////////////////////// REPORTS //////////////////////////////// /*/
.download-wrapper {
    float: right;
    margin-top: -4px;
}
.download-button {
    border: none;
}
.download-button:hover {
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

/* Techlog flight table — scoped modern styling */

/* Horizontally scrollable wrapper so wide tables never overflow the card */
.logsheet-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0 -2px;          /* bleed slightly so border-radius isn't clipped */
}

.logsheet-wrapper th,
.logsheet-wrapper td {
    text-align: center;
    white-space: nowrap;
}

/* Let text-heavy columns wrap */
.logsheet-wrapper td:nth-child(2),   /* Departure */
.logsheet-wrapper td:nth-child(3),   /* Arrival */
.logsheet-wrapper td:nth-child(4),   /* People */
.logsheet-wrapper td:nth-child(5) {  /* PIC */
    white-space: normal;
    min-width: 90px;
}

.logsheet-wrapper table {
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--color-border);
    min-width: 860px;         /* ensures table is readable when scrolled */
}

.logsheet-wrapper th {
    background: var(--color-th-bg);
    color: var(--color-th-text);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border: none;
    border-bottom: 1px solid var(--color-th-border);
    border-right: 1px solid var(--color-border);
    padding: 10px 10px;
}

.logsheet-wrapper th:last-child {
    border-right: none;
}

.logsheet-wrapper td {
    border: none;
    border-bottom: 1px solid #e9ecef;
    border-right: 1px solid #f1f3f5;
    padding: 9px 10px;
    color: #374151;
}

.logsheet-wrapper td:last-child {
    border-right: none;
}

.logsheet-wrapper tbody tr {
    transition: background var(--transition-base);
}

.logsheet-wrapper tbody tr:hover {
    background: var(--color-hover);
}

.logsheet-wrapper tbody tr:nth-child(even) {
    background: #fafbfc;
}

.logsheet-wrapper tbody tr:nth-child(even):hover {
    background: var(--color-hover);
}

/* //////////////////////////////////////////////// FLIGHT FLAGS /////////////////////////////////////// */
/* Compact badges inside PIC column */

.dual-training-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
    vertical-align: baseline;
}

.instruments-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #fce7f3;
    color: #9d174d;
    border: 1px solid #f9a8d4;
    vertical-align: baseline;
}

.night-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #dbeafe;
    color: #1e3a8a;
    border: 1px solid #93c5fd;
    vertical-align: baseline;
}

.solo-flight-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
    vertical-align: baseline;
}

.solo-xc-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #ffedd5;
    color: #c2410c;
    border: 1px solid #fdba74;
    vertical-align: baseline;
}

.qual-xc-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #fce7f3;
    color: #be185d;
    border: 1px solid #f9a8d4;
    vertical-align: baseline;
}

.product-type-hint {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #ede9fe;
    color: #5b21b6;
    border: 1px solid #c4b5fd;
    vertical-align: baseline;
}

/* Clickable flight rows */
.flight-row--clickable {
    cursor: pointer;
}

.flight-row--clickable:hover td {
    background: var(--color-neutral-50, #f8fafc);
}

/* Booked-out flight rows — amber tint */
.flight-row--booked-out td {
    background: var(--color-booked-out-bg, #fffbeb);
}
.flight-row--booked-out:hover td {
    background: var(--color-booked-out-hover, #fef3c7);
}

/* Booked-out banner in flight detail modal */
.fd-booked-out-banner[hidden] {
    display: none;
}
.fd-booked-out-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    margin-bottom: 12px;
    border-radius: 8px;
    background: var(--color-booked-out-banner-bg, #fffbeb);
    border: 1px solid var(--color-booked-out-banner-border, #fbbf24);
    color: var(--color-booked-out-banner-text, #92400e);
    font-size: 14px;
    font-weight: 500;
}

.mini-flag {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    padding: 1px 6px;
    border: 1px solid #cbd5e1;
    border-radius: 999px;
    background: #f8fafc;
    line-height: 1.6;
}

/* Flags editor clean layout */
.flags-editor {
    position: absolute;
    z-index: 1000;
    margin-top: 6px;
    padding: 12px 14px;
    border: 1px solid #d1d5db;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    min-width: 200px;
    font-size: 13px;
}

.flag-options {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}

.flag-option {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #333;
}

.flag-option input[type="checkbox"] {
    accent-color: #2563eb; /* soft blue tick */
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.flags-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.flag-save,
.flag-cancel {
    font-size: 13px;
    padding: 5px 12px;
}


/*////////////////////////// AUTH ALERTS //////////////////////
.auth-alert {
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 14px;
}

/* error (existing behaviour) */
.auth-alert--error {
    background: #fdeeee;
    border: 1px solid #f2c2c2;
    color: #9b1c1c;
}

/* success / neutral */
.auth-alert--success {
    background: #eefaf0;
    border: 1px solid #cfe9d4;
    color: #1f7a3a;
}

/* ═══════════════════════════════════════════════
   TECHLOG RESPONSIVE — TABLET
   ═══════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .container {
        padding: 20px;
        margin: 10px auto;
    }
    .logsheet-wrapper {
        padding: 16px;
    }
    .logsheet-wrapper table {
        font-size: 13px;
    }
    .logsheet-wrapper th {
        padding: 8px 6px;
        font-size: 11px;
    }
    .logsheet-wrapper td {
        padding: 7px 6px;
    }
    .info-grid {
        gap: 6px;
    }
    .info-box {
        padding: 8px 10px;
        font-size: 13px;
    }
}

/* ═══════════════════════════════════════════════
   TECHLOG RESPONSIVE — PHONE
   ═══════════════════════════════════════════════ */
@media (max-width: 720px) {
    body {
        padding: 0;
    }
    .container {
        padding: 12px;
        margin: 0;
        border-radius: 0;
        max-width: 100%;
        box-shadow: none;
    }

    /* --- Topbar mobile --- */
    .topbar {
        flex-wrap: wrap;
        padding: 6px 8px;
        gap: 4px;
    }
    .topbar-left {
        width: 100%;
    }
    .topbar-left .topbar-divider {
        display: none;
    }
    .topbar-right {
        width: 100%;
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: 4px 6px;
        padding-top: 4px;
        border-top: 1px solid #ddd;
        margin-top: 2px;
    }
    .topbar-right .btn,
    .topbar-right .topbar-dropdown-btn {
        padding: 4px 8px;
        font-size: 11px;
    }
    .topbar-org-badge {
        padding: 2px 6px 2px 8px;
    }
    .topbar-org-name { font-size: 11px; }
    .topbar-org-switch { font-size: 11px; }
    .topbar-user { font-size: 12px; }
    .logout-link { font-size: 12px; padding: 3px 8px; }
    .filter-form.techlog-filter {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: flex-start;
        padding: 8px 10px;
        gap: 4px 8px;
        margin-top: 8px;
        margin-bottom: 12px;
        border-radius: 8px;
        text-align: left;
    }
    .filter-form.techlog-filter label {
        flex-direction: row;
        align-items: center;
        text-align: left;
        font-size: 11px;
        gap: 4px;
        white-space: nowrap;
        flex: 0 1 auto;
        min-width: 0;
    }
    /* Aircraft label takes full row */
    .filter-form.techlog-filter label:first-of-type {
        flex: 0 0 100%;
    }
    /* From & To labels share one row */
    .filter-form.techlog-filter label:nth-of-type(2),
    .filter-form.techlog-filter label:nth-of-type(3) {
        flex: 1 1 calc(50% - 8px);
        max-width: calc(50% - 4px);
    }
    .filter-form.techlog-filter select,
    .filter-form.techlog-filter input[type="date"],
    .filter-form.techlog-filter input {
        width: auto;
        min-width: 0;
        height: 28px;
        font-size: 12px;
        padding: 0 4px;
        text-align: left;
    }
    .filter-form.techlog-filter .button-group {
        display: flex;
        flex-wrap: wrap;
        gap: 4px;
        margin-top: 0;
        width: 100%;
        justify-content: flex-start;
    }
    .filter-form.techlog-filter .button-group .btn {
        min-width: 0;
        padding: 4px 8px;
        font-size: 11px;
        height: 28px;
        box-sizing: border-box;
        white-space: nowrap;
        text-align: center;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .filter-form.techlog-filter > .btn {
        box-sizing: border-box;
        height: 28px;
        font-size: 11px;
        padding: 4px 8px;
        text-align: center;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .tabs button,
    .tab-button {
        padding: 8px 14px;
        font-size: 12px;
        white-space: nowrap;
    }
    .logsheet-wrapper {
        padding: 10px;
        border-radius: 8px;
        margin-top: 12px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .logsheet-wrapper table {
        font-size: 12px;
        min-width: 700px;
        width: max-content;
    }
    .logsheet-wrapper th {
        padding: 6px 4px;
        font-size: 10px;
    }
    .logsheet-wrapper td {
        padding: 6px 4px;
        font-size: 12px;
    }
    .info-grid {
        gap: 6px;
    }
    .info-box {
        padding: 8px 10px;
        font-size: 12px;
        min-width: calc(50% - 6px);
    }
    .info-box label {
        font-size: 9px;
    }
    .uplift-section {
        flex-wrap: wrap;
        gap: 10px;
    }
    h2.logsheet-title {
        font-size: 14px;
    }

    /* Modal responsive */
    .modal-panel {
        width: 100%;
        padding: 16px;
        border-radius: 10px;
    }
    .modal-title {
        font-size: 18px;
    }
    .modal-actions .btn {
        flex: 1;
        min-width: 0;
        text-align: center;
    }
    .acheck-sig-pad {
        width: 100% !important;
        height: auto !important;
        max-height: 160px;
    }
    .defect-levels {
        flex-direction: column;
    }
}

/* Final cascade override — .e-icon-link must never show a background */
html body td .e-icon-link:hover,
html body td .e-icon-link:focus,
html body .e-icon-link:hover,
html body .e-icon-link:focus {
    background:       none !important;
    background-color: transparent !important;
    border-radius:    0 !important;
    box-shadow:       none !important;
    color:            var(--color-primary-border);
    opacity:          1;
    outline:          none;
}

/* ═══════════════════════════════════════════════
   BOOKING CALENDAR — DARK THEME
   ═══════════════════════════════════════════════ */

[data-palette="phpstorm_classic"] .calendar-wrapper,
[data-palette="phpstorm_teal"] .calendar-wrapper {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .calendar-header-cell,
[data-palette="phpstorm_teal"] .calendar-header-cell {
    background: var(--color-th-bg);
    color:       var(--color-text) !important;
    border-right-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .calendar-header-cell.today-header,
[data-palette="phpstorm_teal"] .calendar-header-cell.today-header {
    background: var(--color-hover);
    color: var(--color-primary-text) !important;
}

[data-palette="phpstorm_classic"] .calendar-time-cell,
[data-palette="phpstorm_teal"] .calendar-time-cell {
    background:   var(--color-surface);
    color:        var(--color-text-secondary);
    border-right-color: var(--color-border);
    border-bottom-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .calendar-day-cell,
[data-palette="phpstorm_teal"] .calendar-day-cell {
    background:   var(--color-page-bg) !important;
    border-right-color:  var(--color-border) !important;
    border-bottom-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .calendar-day-cell.today-column,
[data-palette="phpstorm_teal"] .calendar-day-cell.today-column {
    background: var(--color-surface) !important;
}

[data-palette="phpstorm_classic"] .calendar-day-cell:hover,
[data-palette="phpstorm_teal"] .calendar-day-cell:hover {
    background: var(--color-hover) !important;
}

/* Booking blocks — soften the hardcoded light palette colours */
[data-palette="phpstorm_classic"] .booking-block,
[data-palette="phpstorm_teal"] .booking-block {
    opacity: 0.9;
}

[data-palette="phpstorm_classic"] .booking-colour-0,
[data-palette="phpstorm_teal"] .booking-colour-0 {
    background:   rgba(130, 170, 255, 0.25) !important;
    border-color: #82aaff !important;
    color:        #c8d8ff !important;
}

[data-palette="phpstorm_classic"] .booking-colour-1,
[data-palette="phpstorm_teal"] .booking-colour-1 {
    background:   rgba(110, 231, 183, 0.2) !important;
    border-color: #6ee7b7 !important;
    color:        #a7f3d0 !important;
}

[data-palette="phpstorm_classic"] .booking-colour-2,
[data-palette="phpstorm_teal"] .booking-colour-2 {
    background:   rgba(255, 216, 102, 0.2) !important;
    border-color: #ffd866 !important;
    color:        #fef3a0 !important;
}

[data-palette="phpstorm_classic"] .booking-colour-3,
[data-palette="phpstorm_teal"] .booking-colour-3 {
    background:   rgba(255, 85, 114, 0.2) !important;
    border-color: #ff5572 !important;
    color:        #ffb3c0 !important;
}

[data-palette="phpstorm_classic"] .booking-colour-4,
[data-palette="phpstorm_teal"] .booking-colour-4 {
    background:   rgba(137, 221, 255, 0.2) !important;
    border-color: #89ddff !important;
    color:        #c0eeff !important;
}

[data-palette="phpstorm_classic"] .booking-colour-5,
[data-palette="phpstorm_teal"] .booking-colour-5 {
    background:   rgba(195, 232, 141, 0.2) !important;
    border-color: #c3e88d !important;
    color:        #dff0b8 !important;
}

[data-palette="phpstorm_classic"] .booking-colour-6,
[data-palette="phpstorm_teal"] .booking-colour-6 {
    background:   rgba(240, 122, 48, 0.2) !important;
    border-color: #f07a30 !important;
    color:        #ffc4a0 !important;
}

[data-palette="phpstorm_classic"] .booking-colour-7,
[data-palette="phpstorm_teal"] .booking-colour-7 {
    background:   rgba(200, 160, 255, 0.2) !important;
    border-color: #c8a0ff !important;
    color:        #e0c8ff !important;
}

/* Modal in dark */
[data-palette="phpstorm_classic"] .modal-content,
[data-palette="phpstorm_teal"] .modal-content {
    background:   var(--color-surface);
    color:        var(--color-text);
}

[data-palette="phpstorm_classic"] .modal-header,
[data-palette="phpstorm_teal"] .modal-header {
    background:   var(--color-th-bg);
    border-bottom-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .modal-header h3,
[data-palette="phpstorm_teal"] .modal-header h3 {
    color: var(--color-th-text);
}

[data-palette="phpstorm_classic"] .modal-footer,
[data-palette="phpstorm_teal"] .modal-footer {
    background:   var(--color-page-bg);
    border-top-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .modal-overlay,
[data-palette="phpstorm_teal"] .modal-overlay {
    background: rgba(0, 0, 0, 0.65);
}

[data-palette="phpstorm_classic"] .form-group label,
[data-palette="phpstorm_teal"] .form-group label {
    color: var(--color-text-secondary);
}

[data-palette="phpstorm_classic"] .form-group select,
[data-palette="phpstorm_classic"] .form-group input,
[data-palette="phpstorm_classic"] .form-group textarea,
[data-palette="phpstorm_teal"] .form-group select,
[data-palette="phpstorm_teal"] .form-group input,
[data-palette="phpstorm_teal"] .form-group textarea {
    background:   var(--color-page-bg) !important;
    color:        var(--color-text) !important;
    border-color: var(--color-border) !important;
}

/* ================================================================
   DARK THEME — WHITE BOX FIXES
   ================================================================ */
[data-palette="phpstorm_classic"] .category-card,
[data-palette="phpstorm_teal"] .category-card {
    background:   var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color:        var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .category-label,
[data-palette="phpstorm_teal"] .category-label {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .category-option input[type="radio"]:checked + .category-card,
[data-palette="phpstorm_teal"] .category-option input[type="radio"]:checked + .category-card {
    background:   var(--color-hover) !important;
    border-color: var(--color-primary-bg) !important;
    box-shadow:   0 0 0 3px rgba(130, 170, 255, 0.2) !important;
}

[data-palette="phpstorm_classic"] .toggle-pill,
[data-palette="phpstorm_teal"] .toggle-pill {
    background:   var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .toggle-label,
[data-palette="phpstorm_teal"] .toggle-label {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .toggle-pill:hover,
[data-palette="phpstorm_teal"] .toggle-pill:hover {
    border-color: var(--color-primary-bg) !important;
    background:   var(--color-hover) !important;
}

[data-palette="phpstorm_classic"] .toggle-pill:has(input:checked),
[data-palette="phpstorm_teal"] .toggle-pill:has(input:checked) {
    border-color: var(--color-primary-bg) !important;
    background:   var(--color-hover) !important;
}

[data-palette="phpstorm_classic"] .flag-badge,
[data-palette="phpstorm_teal"] .flag-badge {
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .flag-on,
[data-palette="phpstorm_teal"] .flag-on {
    background: var(--color-success-bg) !important;
    color:      var(--color-success-text) !important;
}

[data-palette="phpstorm_classic"] .flag-off,
[data-palette="phpstorm_teal"] .flag-off {
    background: var(--color-neutral-bg) !important;
    color:      var(--color-neutral-text) !important;
}

[data-palette="phpstorm_classic"] input[type="checkbox"],
[data-palette="phpstorm_teal"] input[type="checkbox"] {
    accent-color: var(--color-primary-bg);
    color-scheme: dark;
}

[data-palette="phpstorm_classic"] input[type="radio"],
[data-palette="phpstorm_teal"] input[type="radio"] {
    accent-color: var(--color-primary-bg);
    color-scheme: dark;
}

[data-palette="phpstorm_classic"] .form-check,
[data-palette="phpstorm_teal"] .form-check {
    background: transparent !important;
}

[data-palette="phpstorm_classic"] .form-check-label,
[data-palette="phpstorm_teal"] .form-check-label {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .settings-toggle-group .category-option .category-card,
[data-palette="phpstorm_teal"] .settings-toggle-group .category-option .category-card {
    background:   var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .settings-option-example,
[data-palette="phpstorm_teal"] .settings-option-example {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .settings-section-title,
[data-palette="phpstorm_teal"] .settings-section-title {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .settings-section-desc,
[data-palette="phpstorm_teal"] .settings-section-desc {
    color: var(--color-text-secondary) !important;
}

[data-palette="phpstorm_classic"] .people-save-user,
[data-palette="phpstorm_teal"] .people-save-user {
    color: var(--color-text) !important;
}

[data-palette="phpstorm_classic"] .add-defect-field label,
[data-palette="phpstorm_teal"] .add-defect-field label {
    color: var(--color-text-secondary) !important;
}

[data-palette="phpstorm_classic"] .org-card,
[data-palette="phpstorm_teal"] .org-card {
    background:   var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-palette="phpstorm_classic"] .org-card-name,
[data-palette="phpstorm_teal"] .org-card-name {
    color: var(--color-text) !important;
}

/* ================================================================
   DARK THEME — PEOPLE CHECKBOX LIST
   ================================================================ */
[data-palette="phpstorm_classic"] .people-checkbox-list,
[data-palette="phpstorm_teal"] .people-checkbox-list {
    background:   var(--color-surface);
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .people-checkbox-item,
[data-palette="phpstorm_teal"] .people-checkbox-item {
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .people-checkbox-item:has(input:checked),
[data-palette="phpstorm_teal"] .people-checkbox-item:has(input:checked) {
    background: var(--color-hover);
}

[data-palette="phpstorm_classic"] .people-checkbox-item:has(input:checked) .people-checkbox-name,
[data-palette="phpstorm_teal"] .people-checkbox-item:has(input:checked) .people-checkbox-name {
    color: var(--color-primary-bg);
}

/* ================================================================
   HAMBURGER BUTTON — hidden on desktop
   ================================================================ */
.topbar-hamburger {
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 32px;
    height: 24px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    margin-left: auto;
    flex-shrink: 0;
}

.topbar-hamburger span {
    display: block;
    width: 100%;
    height: 3px;
    background: var(--color-text);
    border-radius: 2px;
    transition: transform 0.2s, opacity 0.2s;
}

.topbar-hamburger.is-open span:nth-child(1) {
    transform: translateY(10px) rotate(45deg);
}
.topbar-hamburger.is-open span:nth-child(2) {
    opacity: 0;
}
.topbar-hamburger.is-open span:nth-child(3) {
    transform: translateY(-10px) rotate(-45deg);
}

/* ================================================================
   MOBILE NAV DRAWER — hidden on desktop
   ================================================================ */
.mobile-nav-drawer {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-surface, #fff);
    z-index: 200;
    overflow-y: auto;
    padding: 16px 0 32px;
    border-bottom: 1px solid var(--color-border);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    flex-direction: column;
}

.mobile-nav-drawer:not([hidden]) {
    display: flex;
}

.mobile-nav-drawer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px 16px;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 8px;
}

.mobile-nav-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: var(--color-text);
    padding: 4px 8px;
    line-height: 1;
}

.mobile-nav-item {
    display: block;
    padding: 14px 20px;
    font-size: 15px;
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    border-bottom: 1px solid var(--color-border);
    transition: background 0.15s;
}

.mobile-nav-item:hover,
.mobile-nav-item:active {
    background: var(--color-hover);
}

.mobile-nav-item--bookings {
    color: #ffffff;
    background: #7c3aed;
}

.mobile-nav-item--bookings:hover {
    background: #5b21b6;
}

.mobile-nav-item--defects {
    background: var(--color-danger-bg);
    color: var(--color-danger-text);
}

.mobile-nav-item--weather {
    background: linear-gradient(135deg, #0ea5e9, #22d3ee);
    color: #082f49;
    font-weight: 600;
}
.mobile-nav-item--weather:hover {
    background: linear-gradient(135deg, #0891b2, #06b6d4);
}

.mobile-nav-group {
    border-bottom: 1px solid var(--color-border);
}

.mobile-nav-group-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 14px 20px;
    font-size: 15px;
    font-weight: 500;
    color: var(--color-text);
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: inherit;
}

.mobile-nav-caret {
    font-size: 12px;
    transition: transform 0.2s;
}

.mobile-nav-group-btn.is-open .mobile-nav-caret {
    transform: rotate(180deg);
}

.mobile-nav-group-items {
    background: var(--color-bg-subtle);
    border-top: 1px solid var(--color-border);
}

.mobile-nav-group-items a {
    display: block;
    padding: 12px 28px;
    font-size: 14px;
    color: var(--color-text);
    text-decoration: none;
    border-bottom: 1px solid var(--color-border);
}

.mobile-nav-group-items a:last-child {
    border-bottom: none;
}

.mobile-nav-group-items a:hover {
    background: var(--color-hover);
}

.mobile-nav-footer {
    margin-top: auto;
    padding: 20px 20px 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    border-top: 1px solid var(--color-border);
}

.mobile-nav-org {
    font-weight: 700;
    font-size: 14px;
    color: var(--color-primary-bg);
}

.mobile-nav-switch {
    font-size: 13px;
    color: var(--color-text-secondary);
    text-decoration: underline;
}

.mobile-nav-user {
    font-size: 14px;
    color: var(--color-text);
}

.mobile-nav-logout {
    display: inline-block;
    padding: 10px 20px;
    background: var(--color-danger-bg);
    color: var(--color-danger-text);
    border: 1px solid var(--color-danger-border);
    border-radius: var(--radius-btn);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    text-align: center;
}

/* Dark theme for drawer */
[data-palette="phpstorm_classic"] .mobile-nav-drawer,
[data-palette="phpstorm_teal"] .mobile-nav-drawer {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-palette="phpstorm_classic"] .mobile-nav-group-items,
[data-palette="phpstorm_teal"] .mobile-nav-group-items {
    background: var(--color-page-bg);
}

/* Scroll hint badge */
.scroll-hint {
    display: block;
    text-align: right;
    color: #22c55e;
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 4px;
    opacity: 1;
    transition: opacity 0.4s ease;
}
.scroll-hint.is-hidden {
    opacity: 0;
}

/* ================================================================
   MOBILE — 720px and below (nav + table + filter + defect fixes)
   ================================================================ */
@media (max-width: 720px) {

    /* FIX 8 — Global overflow prevention (clip, not hidden — hidden kills sticky) */
    html, body {
        overflow-x: clip;
        max-width: 100vw;
    }

    * {
        max-width: 100%;
    }

    /* Exemptions for elements that need internal scroll */
    table,
    .logsheet-wrapper table,
    .maintenance-scroll table,
    .logbook-grid__wrap table,
    .table-wrap table,
    .line-items-table-wrap table,
    .users-table {
        max-width: none;
    }

    /* Show hamburger, hide all topbar nav buttons */
    .topbar-hamburger {
        display: flex;
    }

    .topbar-left .btn:not(.btn-nav-techlog),
    .topbar-left .topbar-dropdown-btn,
    .topbar-left .reportsMenu,
    .topbar-left .financeMenu,
    .topbar-left .settingsMenu,
    .topbar-left .trainingMenu,
    .topbar-left .topbar-divider,
    .topbar-right .btn:not(.logout-link),
    .topbar-right .myAccountMenu,
    .topbar-right .topbar-org-badge,
    .topbar-right .topbar-divider,
    .topbar-right .topbar-user,
    .topbar-right .logout-link {
        display: none !important;
    }

    /* Keep topbar minimal — Techlog + hamburger only */
    .topbar {
        flex-wrap: nowrap;
        justify-content: space-between;
        align-items: center;
        padding: 10px 16px;
    }

    .topbar-left {
        width: auto;
        flex: 1;
    }

    .topbar-right {
        width: auto;
        border: none;
        padding: 0;
        margin: 0;
        justify-content: flex-end;
    }

    /* FIX 5 — Techlog button alignment */
    .btn-nav-techlog {
        display: inline-flex !important;
        font-size: 13px;
        padding: 6px 12px;
        height: 36px;
        background: var(--color-primary-bg);
        color: var(--color-primary-text);
        border-color: var(--color-primary-border);
        font-weight: 700;
        border-radius: var(--radius-btn);
    }

    /* FIX 1 — Finance / billing / invoices filter overflow + summary overlap */
    .container {
        overflow-x: hidden;
        width: 100%;
        box-sizing: border-box;
        padding: 10px;
    }

    .finance-filters,
    .filter-form,
    .form-inline.reports-filters {
        display: flex;
        flex-direction: column;
        width: 100%;
        box-sizing: border-box;
        padding: 12px;
        gap: 8px;
        overflow: visible;
    }

    .finance-filters label,
    .finance-filters .filter-group,
    .finance-filters > div,
    .filter-form label,
    .filter-form > div,
    .reports-filters .form-group {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        flex: 0 0 100% !important;
        box-sizing: border-box;
    }

    .finance-filters select,
    .finance-filters input,
    .filter-form select,
    .filter-form input[type="date"],
    .filter-form input[type="text"],
    .filter-form input[type="number"],
    .reports-filters select,
    .reports-filters input[type="date"] {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        height: 44px;
        font-size: 16px;
    }

    .finance-filters .button-group,
    .filter-form .button-group {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }

    .finance-filters .button-group .btn,
    .filter-form .button-group .btn {
        flex: 1;
        min-width: 80px;
        height: 44px;
        font-size: 14px;
    }

    .billing-summary,
    .reports-summary,
    .invoice-summary,
    .finance-summary {
        width: 100%;
        box-sizing: border-box;
        margin-bottom: 16px;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        background: var(--color-surface);
        border: 1px solid var(--color-border);
        border-radius: var(--radius-card);
        padding: 12px;
    }

    .billing-summary > div,
    .finance-summary > div {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

    .billing-table-wrap,
    .invoices-table-wrap,
    .finance-table-wrap,
    .reports-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        width: 100%;
    }

    .container > table,
    .container > .filter-form + table {
        min-width: 500px;
        width: max-content;
    }

    /* FIX 2 — Techlog filter: compact layout */
    .filter-form.techlog-filter {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 6px;
        padding: 8px 10px;
    }

    .filter-form.techlog-filter label {
        flex: 0 0 100% !important;
    }

    .filter-form.techlog-filter label:nth-of-type(2),
    .filter-form.techlog-filter label:nth-of-type(3) {
        flex: 1 1 calc(50% - 4px) !important;
        max-width: calc(50% - 4px) !important;
    }

    .filter-form.techlog-filter select,
    .filter-form.techlog-filter input[type="date"] {
        height: 36px;
        font-size: 14px;
        width: 100%;
    }

    .filter-form.techlog-filter .button-group {
        display: flex;
        flex-wrap: nowrap;
        width: 100%;
        gap: 4px;
    }

    .filter-form.techlog-filter .button-group .btn {
        flex: 1;
        height: 36px;
        font-size: 12px;
        padding: 0 6px;
        min-width: 0;
    }

    /* FIX 3 — Maintenance summary: 2x2 grid with paired header+value */
    .maintenance-scroll {
        overflow-x: visible;
        margin-top: 10px;
    }

    .maintenance-scroll .maintenance-title-row {
        display: none;
    }

    /* Flatten table structure into a single 2-column grid */
    .maintenance-scroll table {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        width: 100%;
        min-width: 0;
    }
    .maintenance-scroll table thead,
    .maintenance-scroll table tbody,
    .maintenance-scroll thead tr:not(.maintenance-title-row),
    .maintenance-scroll tbody tr {
        display: contents;
    }

    /* Interleave: header then value for each pair */
    .maintenance-scroll thead tr:not(.maintenance-title-row) th:nth-child(1) { order: 1; }
    .maintenance-scroll thead tr:not(.maintenance-title-row) th:nth-child(2) { order: 2; }
    .maintenance-scroll tbody td:nth-child(1) { order: 3; }
    .maintenance-scroll tbody td:nth-child(2) { order: 4; }
    .maintenance-scroll thead tr:not(.maintenance-title-row) th:nth-child(3) { order: 5; }
    .maintenance-scroll thead tr:not(.maintenance-title-row) th:nth-child(4) { order: 6; }
    .maintenance-scroll tbody td:nth-child(3) { order: 7; }
    .maintenance-scroll tbody td:nth-child(4) { order: 8; }

    .maintenance-scroll thead th {
        background: var(--color-bg-subtle);
        border: 1px solid var(--color-border);
        border-radius: 6px 6px 0 0;
        padding: 6px 8px;
        font-size: 9px;
        text-transform: uppercase;
        letter-spacing: 0.3px;
        color: var(--color-text-secondary);
        font-weight: 700;
        white-space: normal;
        text-align: center;
        border-bottom: none;
        box-sizing: border-box;
    }

    .maintenance-scroll tbody td {
        background: var(--color-bg-subtle);
        border: 1px solid var(--color-border);
        border-radius: 0 0 6px 6px;
        padding: 8px;
        font-size: 15px;
        font-weight: 700;
        text-align: center;
        border-top: none;
        box-sizing: border-box;
    }

    /* Table overflow fixes */
    .users-table-card {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .users-table {
        min-width: 560px;
    }
    .users-table-wrap,
    .finance-table-wrap,
    .invoices-table-wrap,
    .line-items-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        width: 100%;
    }

    .users-td-actions {
        white-space: nowrap;
    }

    .users-td-actions form {
        display: inline;
    }

    .users-td-actions .btn {
        box-sizing: border-box;
        -webkit-appearance: none;
        appearance: none;
        height: 32px;
        padding: 4px 12px;
        font-size: 13px;
        line-height: 1.4;
    }

    /* PART 4 — Defects add form */
    .add-defect-section .add-defect-row {
        flex-direction: column;
        gap: 10px;
    }

    .add-defect-section textarea,
    .add-defect-section input[type="text"] {
        width: 100% !important;
        box-sizing: border-box;
    }

    #defect-modal-description,
    #defect-modal-notes {
        width: 100% !important;
        box-sizing: border-box;
    }

    /* FIX 6 — Logbook summary and flights table scroll */
    .logbook-grid__wrap,
    .table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        width: 100%;
    }

    .logbook-grid__wrap table {
        min-width: 420px;
        width: 100%;
    }

    .table-wrap table {
        min-width: 420px;
        width: 100%;
    }

    .logbook-grid__wrap,
    .table-wrap {
        max-width: 100%;
    }

    /* FIX 7 — Invoice detail page */
    .invoice-top-row {
        flex-direction: column;
    }

    .invoice-meta-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .invoice-pilot-select,
    .invoice-meta-grid select {
        width: 100% !important;
        max-width: 200px;
        height: 40px;
        font-size: 15px;
    }

    .invoice-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        margin-bottom: 16px;
    }

    .invoice-actions .btn {
        height: 40px;
        font-size: 13px;
        padding: 0 12px;
        white-space: nowrap;
    }

    .line-items-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .line-items-table-wrap table {
        min-width: 500px;
    }

    .invoice-header {
        display: flex;
        flex-direction: column;
        gap: 8px;
        margin-bottom: 0;
    }

    .invoice-number {
        font-size: 22px;
        font-weight: 700;
    }

    .invoice-status-badge {
        display: inline-block;
        width: fit-content;
    }

    /* Aircraft Usage Summary — vertical card layout */
    .aircraft-usage-table thead {
        display: none;
    }

    .aircraft-usage-table tbody tr {
        display: grid;
        grid-template-columns: 1fr;
        gap: 1px;
        margin-bottom: 12px;
        border: 1px solid var(--color-border);
        border-radius: var(--radius-sm);
        overflow: hidden;
    }

    .aircraft-usage-table td {
        display: flex;
        flex-direction: column;
        padding: 10px 12px;
        background: var(--color-surface, #fff);
        border: none !important;
        border-bottom: 1px solid var(--color-border) !important;
    }

    .aircraft-usage-table td::before {
        content: attr(data-label);
        display: block;
        font-size: 9px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.4px;
        color: var(--color-text-secondary);
        margin-bottom: 4px;
    }

    .aircraft-usage-table td:last-child {
        border-bottom: none !important;
    }

    /* Booking modal — scrollable on mobile Safari */
    .modal-overlay {
        align-items: flex-start;
    }
    .modal-content {
        display: flex;
        flex-direction: column;
        max-height: 90dvh;
        margin-top: 5dvh;
    }
    .modal-body {
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        flex: 1;
    }

    /* Sticky topbar on mobile */
    .topbar {
        position: sticky;
        top: 0;
        z-index: 100;
    }

    /* Prevent delete-button forms from stretching full width */
    .users-td-actions form,
    td form {
        display: inline-flex;
    }

    .users-td-actions form .btn,
    td form .btn {
        width: auto;
    }
}

/* ================================================================
   MOBILE — 480px and below (iPhone)
   ================================================================ */
@media (max-width: 480px) {

    /* FIX 1 — Prevent iOS zoom on input focus */
    input,
    select,
    textarea {
        font-size: 16px !important;
    }

    /* FIX 2 — Minimum tap target size */
    .btn {
        min-height: 44px;
        padding: 10px 16px;
        font-size: 14px;
    }
    .topbar-left .btn,
    .topbar-right .btn,
    .topbar-dropdown-btn {
        min-height: 36px;
        padding: 6px 10px;
        font-size: 12px;
    }

    /* FIX 3 — Filter forms stack vertically */
    .filter-form {
        flex-direction: column;
        align-items: stretch;
        padding: 12px;
        gap: 10px;
    }
    .filter-form label {
        flex: 0 0 100% !important;
        max-width: 100% !important;
        min-width: 0;
        width: 100%;
        flex-direction: column;
    }
    .filter-form select,
    .filter-form input[type="date"],
    .filter-form input[type="text"],
    .filter-form input[type="number"] {
        width: 100% !important;
        max-width: 100% !important;
        height: 44px;
        box-sizing: border-box;
    }
    .filter-form .button-group {
        width: 100%;
        justify-content: stretch;
    }
    .filter-form .button-group .btn {
        flex: 0 1 auto;
        max-width: fit-content;
        height: 44px;
        font-size: 14px;
    }
    .filter-form.techlog-filter .button-group {
        display: flex;
        flex-wrap: nowrap;
        width: 100%;
        gap: 4px;
    }
    .filter-form.techlog-filter .button-group .btn {
        flex: 1;
        min-width: 0;
        max-width: none;
        height: 44px;
        font-size: 13px;
        padding: 0 4px;
    }

    /* Collapsible filters on mobile */
    .filter-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 10px 0;
        border: none;
        background: none;
        font-size: 15px;
        font-weight: 700;
        color: var(--color-text);
        cursor: pointer;
        font-family: inherit;
    }
    .filter-body {
        display: none;
        flex-direction: column;
        gap: 10px;
    }
    .filter-body.is-open {
        display: flex;
    }
    .form-inline.reports-filters {
        flex-direction: column;
        align-items: stretch;
    }
    .reports-filters .form-group {
        max-width: 100%;
        min-width: unset;
        flex: 0 0 100%;
    }
    .reports-filters select,
    .reports-filters input[type="date"] {
        height: 44px;
        width: 100%;
    }
    .reports-filters button.btn {
        width: 100%;
        height: 44px;
        font-size: 15px;
    }

    /* FIX 4 — Billing settings add form */
    .bc-add-grid {
        grid-template-columns: 1fr !important;
    }
    .aircraft-form-grid {
        grid-template-columns: 1fr !important;
    }
    .category-option {
        flex: 1 1 calc(50% - 6px);
        max-width: calc(50% - 6px);
    }

    /* FIX 5 — Role toggle pills 2x2 grid */
    .aircraft-toggles,
    .settings-toggle-group {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }
    .toggle-pill {
        width: 100%;
        justify-content: flex-start;
        padding: 12px;
        min-height: 44px;
    }

    /* FIX 6 — Booking modal date+time same row */
    .form-row {
        display: flex;
        flex-direction: row;
        gap: 8px;
    }
    .form-row .form-group {
        flex: 1;
    }
    .form-group select,
    .form-group input {
        min-height: 44px;
    }

    /* FIX 7 — Info boxes 2-column on mobile */
    .info-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
    }
    .info-box {
        min-width: unset;
        flex: unset;
    }

    /* FIX 8 — Finance email recipients card layout */
    .finance-recipients-table thead {
        display: none;
    }
    .finance-recipients-table tr {
        display: block;
        padding: 10px 0;
        border-bottom: 1px solid var(--color-border);
    }
    .finance-recipients-table td {
        display: block;
        border: none;
        padding: 2px 0;
    }
    .finance-recipients-table td:first-child {
        font-weight: 600;
        font-size: 14px;
        color: var(--color-text);
    }
    .finance-recipients-table td:last-child {
        font-size: 13px;
        color: var(--color-text-secondary);
    }

    /* Paginated tables: scrollable on mobile instead of sticky */
    .users-table-wrap--paginated {
        overflow-x: auto !important;
        overflow-y: visible !important;
    }
    .users-table-wrap--paginated .users-table {
        min-width: 600px;
        width: max-content;
    }
    .users-table-wrap--paginated .users-table thead th {
        position: static !important;
    }
    .users-table-wrap--paginated .users-table {
        border-collapse: separate;
        border-spacing: 0;
    }

    /* FIX 9 — Horizontal scroll indicator */
    .logsheet-wrapper {
        position: relative;
    }
    .logsheet-wrapper::after {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        width: 32px;
        height: 100%;
        background: linear-gradient(
            to right,
            transparent,
            rgba(0, 0, 0, 0.15)
        );
        pointer-events: none;
        border-radius: 0 var(--radius-card) var(--radius-card) 0;
    }
}

/* ================================================================
   STICKY FIRST COLUMN — restrictive tables
   ================================================================ */
/* border-collapse: collapse prevents sticky left — switch to separate */
.restrictive-tbl {
    border-collapse: separate;
    border-spacing: 0;
}

.restrictive-tbl thead th:first-child,
.restrictive-tbl tbody td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    background: var(--color-th-bg);
}

.restrictive-tbl tbody td:first-child {
    background: var(--color-surface, #fff);
    z-index: 1;
}

/* Highlighted rows: sticky cell must match the row background */
.restrictive-tbl tr.restrictive-row-expired td:first-child {
    background: var(--color-danger-bg, #fee2e2);
}
.restrictive-tbl tr.restrictive-row-expiring td:first-child {
    background: #fefce8;
}
.restrictive-tbl tr.row-completed td:first-child {
    background: #f9fafb;
}

/* Dark theme: sticky cells get the surface colour */
[data-palette="phpstorm_classic"] .restrictive-tbl tbody td:first-child,
[data-palette="phpstorm_teal"] .restrictive-tbl tbody td:first-child {
    background: var(--color-surface) !important;
}

/* ================================================================
   STICKY FIRST COLUMN — aircraft settings table
   ================================================================ */
.aircraft-settings-table {
    border-collapse: separate;
    border-spacing: 0;
}

/* All headers: sticky top for vertical scroll */
.aircraft-settings-table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
}

/* First header cell: dual-axis sticky (top + left), highest z-index */
.aircraft-settings-table thead th:first-child {
    left: 0;
    z-index: 3;
}

/* First data cell: sticky left for horizontal scroll */
.aircraft-settings-table tbody td:first-child {
    position: sticky;
    left: 0;
    z-index: 1;
    background: var(--color-surface, var(--color-bg-subtle));
}

[data-palette="phpstorm_classic"] .aircraft-settings-table td:first-child,
[data-palette="phpstorm_teal"] .aircraft-settings-table td:first-child {
    background: var(--color-surface) !important;
}

/* =========================
   FLIGHT DETAIL MODAL
   ========================= */

.flight-detail-modal {
    background: var(--color-surface, #fff);
    color: var(--color-text, #1e293b);
    border-radius: 16px;
    max-width: 880px;
    width: 95%;
    max-height: 96vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.25);
    overflow: hidden;
    animation: fdSlideIn 0.2s ease-out;
}

@keyframes fdSlideIn {
    from { opacity: 0; transform: translateY(8px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.flight-detail-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
    flex-shrink: 0;
}

.flight-detail-header .modal-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-primary-bg, var(--color-link, #0072ce));
}

.flight-detail-header .modal-close {
    background: none;
    border: none;
    color: var(--color-text-secondary, #94a3b8);
    font-size: 1.4rem;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
    border-radius: 6px;
    transition: background 0.15s, color 0.15s;
}

.flight-detail-header .modal-close:hover {
    background: var(--color-border, #e2e8f0);
    color: var(--color-text, #1e293b);
}

.flight-detail-body {
    flex: 1;
    overflow-y: auto;
    padding: 14px 20px;
}

.flight-detail-footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    border-top: 1px solid var(--color-border, #e2e8f0);
    background: var(--color-th-bg, #f8f9fa);
    border-radius: 0 0 16px 16px;
    flex-shrink: 0;
}

.flight-detail-loading {
    text-align: center;
    padding: 32px 20px;
    color: var(--color-text-muted, #64748b);
    font-size: 0.9rem;
}

/* --- Sections --- */
.fd-section {
    margin-bottom: 14px;
}

.fd-section:last-child {
    margin-bottom: 0;
}

/* --- Two-column body layout --- */
.fd-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 24px;
}

.fd-col {
    min-width: 0;
}

.fd-section-title {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted, #94a3b8);
    margin: 0 0 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
}

/* --- Grid & Fields --- */
.fd-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 20px;
}

.fd-field {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

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

.fd-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text-muted, #94a3b8);
    letter-spacing: 0.02em;
}

.fd-required-star {
    color: var(--color-purple, #a855f7);
    font-weight: 700;
    font-size: 0.85rem;
}

.fd-value {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text, #1e293b);
}

/* Highlight computed numbers */
.fd-value--accent {
    color: var(--color-primary-bg, #0072ce);
}

/* --- Inputs --- */
.fd-input {
    padding: 6px 10px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 8px;
    font-size: 0.88rem;
    background: var(--color-bg-subtle, #f8fafc);
    color: var(--color-text, #1e293b);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.fd-input:focus {
    outline: none;
    border-color: var(--color-primary-bg, #0072ce);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary-bg, #0072ce) 12%, transparent);
    background: var(--color-surface, #fff);
}

.fd-textarea {
    resize: vertical;
    min-height: 48px;
}

/* --- Badges (flags) --- */
.fd-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.fd-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 12px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.fd-badge--training {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}

.fd-badge--instruments {
    background: #fce7f3;
    color: #9d174d;
    border: 1px solid #f9a8d4;
}

.fd-badge--night {
    background: #dbeafe;
    color: #1e3a8a;
    border: 1px solid #93c5fd;
}

.fd-badge--solo {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}

.fd-badge--solo-xc {
    background: #ffedd5;
    color: #c2410c;
    border: 1px solid #fdba74;
}

.fd-badge--qual-xc {
    background: #fce7f3;
    color: #be185d;
    border: 1px solid #f9a8d4;
}

.fd-badge--product-type {
    background: #ede9fe;
    color: #5b21b6;
    border: 1px solid #c4b5fd;
}

.fd-badge--removable {
    padding-right: 6px;
    cursor: default;
}

.fd-badge-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    margin-left: 4px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.12);
    color: inherit;
    font-size: 11px;
    line-height: 1;
    cursor: pointer;
    vertical-align: middle;
    transition: background 0.15s;
}

.fd-badge-remove:hover {
    background: rgba(0, 0, 0, 0.25);
}

.fd-badge--add {
    cursor: pointer;
    background: transparent;
    color: var(--color-text-muted, #94a3b8);
    border: 1px dashed var(--color-border, #d1d5db);
    font-size: 0.75rem;
    font-weight: 500;
    padding: 3px 12px;
    border-radius: 999px;
    transition: color 0.15s, border-color 0.15s;
}

.fd-badge--add:hover {
    border-color: var(--color-primary-bg, #0072ce);
    color: var(--color-primary-bg, #0072ce);
}

/* --- Defects --- */
.fd-defect-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.fd-defect-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
}

/* --- People tags --- */
.fd-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    min-height: 30px;
    padding: 5px 8px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 8px;
    background: var(--color-bg-subtle, #f8fafc);
    align-items: center;
}

.fd-tag {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 500;
    background: color-mix(in srgb, var(--color-primary-bg, #0072ce) 10%, transparent);
    color: var(--color-primary-bg, #0072ce);
    border: 1px solid color-mix(in srgb, var(--color-primary-bg, #0072ce) 25%, transparent);
}

.fd-tag--removable {
    padding-right: 4px;
}

.fd-tag-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    margin-left: 4px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.1);
    color: inherit;
    font-size: 11px;
    line-height: 1;
    cursor: pointer;
    transition: background 0.15s;
}

.fd-tag-remove:hover {
    background: rgba(0, 0, 0, 0.25);
}

/* --- Add person row --- */
.fd-add-row {
    display: flex;
    gap: 8px;
    margin-top: 6px;
}

.fd-add-input {
    flex: 1;
    min-width: 0;
    font-size: 0.82rem !important;
    padding: 4px 8px !important;
}

/* --- Defect toggle buttons --- */
.fd-defect-toggle {
    margin-left: auto;
    padding: 0;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 1px solid var(--color-border, #d1d5db);
    background: transparent;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.fd-defect-toggle--remove {
    color: #991b1b;
    border-color: #fca5a5;
}

.fd-defect-toggle--remove:hover {
    background: #fef2f2;
}

.fd-add-level {
    flex: 0 0 auto;
    width: 52px;
    text-align: center;
    padding-left: 4px !important;
    padding-right: 4px !important;
}

.fd-add-btn {
    flex: 0 0 auto;
    padding: 4px 10px !important;
    font-size: 1rem;
    line-height: 1;
}

/* --- Booking card --- */
.fd-booking-card {
    margin-top: 8px;
    padding: 10px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 10px;
    background: var(--color-bg-subtle, #f8fafc);
    font-size: 0.85rem;
}

.fd-booking-card-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
}

.fd-booking-card-label {
    font-weight: 600;
    color: var(--color-text-muted, #94a3b8);
    font-size: 0.8rem;
}

/* --- Training flight-type checkboxes --- */
.fd-training-flags {
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 10px;
    padding: 8px 0;
}

.fd-training-flags .fd-pic-prompt-label {
    width: 100%;
    margin-bottom: 0;
}

/* --- PIC prompt --- */
.fd-pic-prompt {
    margin-top: 8px;
    padding: 10px;
    border: 1px solid color-mix(in srgb, #f59e0b 40%, transparent);
    border-radius: 10px;
    background: color-mix(in srgb, #f59e0b 6%, transparent);
}

.fd-pic-prompt-label {
    font-weight: 600;
    margin: 0 0 6px;
    font-size: 0.85rem;
    color: var(--color-text, #1e293b);
}

/* --- Dot-style radio buttons --- */
.fd-radio {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: 3px 0;
    font-size: 0.88rem;
}

.fd-radio input[type="radio"] {
    display: none;
}

.fd-radio-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-border, #d1d5db);
    transition: background 0.2s, box-shadow 0.2s;
    flex-shrink: 0;
}

.fd-radio input[type="radio"]:checked + .fd-radio-dot {
    background: var(--color-primary-bg, #0072ce);
    box-shadow: 0 0 6px 2px color-mix(in srgb, var(--color-primary-bg, #0072ce) 50%, transparent);
}

/* --- Links --- */
.fd-invoice-link {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-primary-bg, #0072ce);
    text-decoration: none;
    transition: opacity 0.15s;
}

.fd-invoice-link:hover {
    opacity: 0.75;
}

/* --- Error --- */
.fd-error {
    width: 100%;
    padding: 8px 12px;
    border-radius: 8px;
    background: #fef2f2;
    color: #991b1b;
    font-size: 0.83rem;
    font-weight: 500;
    border: 1px solid #fca5a5;
}

/* --- Mobile --- */
@media (max-width: 700px) {
    .flight-detail-modal {
        max-width: 100%;
        max-height: 100%;
        height: 100%;
        border-radius: 0;
    }
    .flight-detail-header { padding: 10px 14px; }
    .flight-detail-body { padding: 10px 14px; }
    .flight-detail-footer { padding: 8px 14px; border-radius: 0; }
    .fd-columns { grid-template-columns: 1fr; gap: 0; }
    .fd-section { margin-bottom: 10px; }
    .fd-section-title { margin-bottom: 6px; padding-bottom: 4px; font-size: 0.65rem; }
    .fd-grid { gap: 8px 12px; }
    .fd-field { gap: 2px; }
    .fd-label { font-size: 0.7rem; }
    .fd-value { font-size: 0.88rem; }
    .fd-input { padding: 5px 8px; font-size: 0.85rem; }
    .fd-textarea { min-height: 40px; }
    .fd-booking-card { padding: 8px; margin-top: 6px; }
    .fd-pic-prompt { padding: 8px; margin-top: 6px; }
    .fd-tags { min-height: 28px; padding: 4px 6px; }
    .fd-badge { padding: 2px 10px; font-size: 0.72rem; }
    .fd-add-row { flex-direction: column; gap: 4px; }
}