@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@600;700;800&display=swap');

:root {
  --ink: #12323a;
  --muted: #71878c;
  --navy: #082f3a;
  --navy-2: #0d4350;
  --sea: #0a7f83;
  --sea-soft: #e0f2ef;
  --mint: #92d5c5;
  --sand: #f5d7a4;
  --paper: #f4f7f6;
  --white: #fff;
  --line: #dce6e4;
  --danger: #c94b4b;
  --shadow: 0 18px 50px rgba(15, 54, 61, .12);
  --radius: 18px;
}

* { box-sizing: border-box; }
body { margin: 0; min-width: 320px; color: var(--ink); background: var(--paper); font-family: "DM Sans", sans-serif; }
button, input, select, textarea { font: inherit; }
button { color: inherit; cursor: pointer; }
.hidden { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.eyebrow { display: block; color: var(--sea); font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow.light { color: #9ed5d1; }
.muted { color: var(--muted); }

.login-screen { min-height: 100vh; display: grid; grid-template-columns: minmax(390px, 1.1fr) minmax(440px, .9fr); background: var(--white); }
.login-art { position: relative; overflow: hidden; min-height: 100vh; padding: 48px 7vw; display: flex; flex-direction: column; justify-content: space-between; color: white; background: radial-gradient(circle at 20% 10%, #126778 0, transparent 32%), linear-gradient(155deg, #082f3a 0%, #095562 100%); }
.brand-lockup, .side-brand { display: flex; align-items: center; gap: 16px; }
.brand-logo { flex: 0 0 auto; display: flex; align-items: center; justify-content: center; }
.brand-logo img { width: 100%; height: auto; display: block; object-fit: contain; }
.login-brand-logo { width: 118px; }
.side-brand-logo { width: 68px; }
.brand-lockup h1 { margin: 2px 0 0; font: 800 27px/1 Manrope, sans-serif; letter-spacing: -.06em; text-transform: uppercase; }
.login-message { position: relative; z-index: 1; max-width: 560px; padding-bottom: 10vh; }
.login-message h2 { margin: 12px 0 18px; font: 800 clamp(42px, 5vw, 74px)/1.02 Manrope, sans-serif; letter-spacing: -.07em; }
.login-message p:last-child { max-width: 440px; color: #c2dcdd; font-size: 17px; line-height: 1.6; }
.wave-lines { position: absolute; right: -18%; bottom: -18%; width: 82%; aspect-ratio: 1; border: 1px solid rgba(255,255,255,.11); border-radius: 46% 54% 65% 35%; transform: rotate(28deg); box-shadow: 0 0 0 45px rgba(255,255,255,.025), 0 0 0 100px rgba(255,255,255,.02), 0 0 0 160px rgba(255,255,255,.018); }
.login-panel { display: grid; place-items: center; align-content: center; padding: 40px; position: relative; }
.pin-card { width: min(100%, 350px); }
.pin-card h2 { margin: 7px 0 4px; font: 800 36px/1.1 Manrope, sans-serif; letter-spacing: -.05em; }
.pin-input { width: 100%; height: 66px; margin: 24px 0 16px; border: 1px solid var(--line); border-radius: 14px; background: var(--paper); text-align: center; font-size: 30px; letter-spacing: .55em; padding-left: .55em; color: var(--navy); outline: none; }
.pin-input:focus { border-color: var(--sea); box-shadow: 0 0 0 4px rgba(10,127,131,.1); }
.keypad { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; }
.keypad button { height: 54px; border: 1px solid var(--line); border-radius: 12px; background: white; font-weight: 700; transition: .18s ease; }
.keypad button:hover { background: var(--sea-soft); border-color: #b3d8d3; transform: translateY(-1px); }
.form-error { min-height: 18px; margin: 8px 0; color: var(--danger); font-size: 13px; text-align: center; }
.login-foot { position: absolute; bottom: 22px; color: #a0afaf; font-size: 12px; }

.button { min-height: 42px; padding: 0 17px; border: 1px solid transparent; border-radius: 10px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; font-weight: 700; transition: .18s ease; }
.button:hover { transform: translateY(-1px); }
.button.primary { color: white; background: var(--sea); box-shadow: 0 8px 18px rgba(10,127,131,.2); }
.button.primary:hover { background: #086c70; }
.button.ghost { border-color: var(--line); background: white; }
.button.danger { border-color: #f2cccc; color: var(--danger); background: #fff5f5; }
.button.wide { width: 100%; }
.button.small { min-height: 36px; padding: 0 12px; font-size: 12px; }
.icon-button { width: 38px; height: 38px; padding: 0; border: 1px solid var(--line); border-radius: 10px; background: white; font-size: 23px; }

.app { min-height: 100vh; }
.sidebar { position: fixed; inset: 0 auto 0 0; z-index: 10; width: 225px; padding: 26px 18px; display: flex; flex-direction: column; color: #dcebec; background: var(--navy); }
.mobile-close-menu { display: none; position: absolute; top: 12px; right: 12px; width: 34px; height: 34px; border: 1px solid rgba(255,255,255,.2); border-radius: 9px; color: white; background: transparent; font-size: 22px; }
.side-brand { padding: 0 8px 26px; border-bottom: 1px solid rgba(255,255,255,.1); }
.side-brand strong { display: block; color: white; font: 800 16px Manrope, sans-serif; }
.side-brand span { color: #85aeb3; font-size: 11px; }
.side-nav { display: grid; gap: 7px; margin-top: 28px; }
.nav-item { width: 100%; padding: 12px 13px; border: 0; border-radius: 10px; display: flex; align-items: center; gap: 11px; color: #a8c4c7; background: transparent; text-align: left; font-size: 13px; font-weight: 700; }
.nav-item span { width: 19px; color: #81c9c7; font-size: 18px; text-align: center; }
.nav-item:hover, .nav-item.active { color: white; background: rgba(255,255,255,.1); }
.side-bottom { margin-top: auto; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.1); }
.mini-weather { display: flex; align-items: center; gap: 10px; }
.weather-icon { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: var(--navy); background: var(--mint); font-size: 22px; }
.mini-weather strong, .mini-weather span { display: block; }
.mini-weather strong { color: #dcebec; font-size: 11px; }
.mini-weather div span { margin-top: 2px; color: #779ba0; font-size: 9px; }

.main { min-height: 100vh; margin-left: 225px; }
.topbar { height: 88px; padding: 0 32px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,.88); backdrop-filter: blur(12px); }
.topbar h1 { margin: 4px 0 0; font: 800 22px Manrope, sans-serif; letter-spacing: -.04em; }
.top-actions { display: flex; align-items: center; gap: 14px; }
.user-menu-wrap { position: relative; }
.user-chip { padding: 5px 8px 5px 5px; border: 1px solid var(--line); border-radius: 12px; display: flex; align-items: center; gap: 9px; background: white; text-align: left; }
.user-chip span:nth-child(2) { min-width: 90px; }
.user-chip strong, .user-chip small { display: block; }
.user-chip strong { font-size: 12px; }
.user-chip small { margin-top: 1px; color: var(--muted); font-size: 9px; }
.avatar { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: white; background: var(--navy-2); font-weight: 800; }
.dropdown { position: absolute; top: calc(100% + 8px); right: 0; z-index: 20; width: 225px; padding: 7px; border: 1px solid var(--line); border-radius: 12px; background: white; box-shadow: var(--shadow); }
.dropdown button { width: 100%; padding: 10px 11px; border: 0; border-radius: 8px; background: white; text-align: left; font-size: 12px; font-weight: 700; }
.dropdown button:hover { background: var(--paper); }
.dropdown hr { height: 1px; margin: 6px 3px; border: 0; background: var(--line); }
.content-view { padding: 25px 32px 36px; }
.summary-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 15px; margin-bottom: 20px; }
.summary-card { min-height: 83px; padding: 15px; border: 1px solid var(--line); border-radius: 14px; display: flex; align-items: center; gap: 13px; background: white; }
.summary-icon { width: 43px; height: 43px; border-radius: 11px; display: grid; place-items: center; font-size: 19px; font-weight: 800; }
.summary-icon.mint { color: #17675e; background: #d9f0eb; }
.summary-icon.blue { color: #285e7b; background: #deedf5; }
.summary-icon.sand { color: #936c30; background: #f8ecd6; }
.summary-card span:not(.summary-icon) { display: block; color: var(--muted); font-size: 11px; }
.summary-card strong { display: block; margin-top: 3px; font: 800 21px Manrope, sans-serif; }

.calendar-card, .list-card { border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 8px 30px rgba(23,58,63,.05); overflow: hidden; }
.calendar-toolbar { padding: 16px 18px; display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.month-switcher, .filters { display: flex; align-items: center; gap: 8px; }
.month-label { min-width: 150px; border: 0; background: transparent; font: 800 17px Manrope, sans-serif; text-transform: capitalize; }
.search-field { width: 220px; height: 38px; padding: 0 10px; border: 1px solid var(--line); border-radius: 9px; display: flex; align-items: center; gap: 6px; color: var(--muted); background: var(--paper); }
.search-field input { width: 100%; border: 0; outline: 0; color: var(--ink); background: transparent; font-size: 12px; }
.filters select, label select, label input, label textarea { width: 100%; border: 1px solid var(--line); border-radius: 9px; color: var(--ink); background: white; outline: none; }
.filters select { width: 140px; height: 38px; padding: 0 9px; background: var(--paper); font-size: 12px; }
.legend { padding: 9px 18px; border-top: 1px solid var(--line); display: flex; gap: 18px; color: var(--muted); background: #fbfdfc; font-size: 10px; font-weight: 600; }
.legend span { display: flex; align-items: center; gap: 5px; }
.dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; }
.free-dot { background: #a9c5c1; }
.booked-dot { background: var(--sea); }
.option-dot { background: #d5a044; }
.due-dot { background: var(--danger); }
.calendar-scroll { overflow: auto; max-height: calc(100vh - 330px); }
.booking-table { width: 100%; min-width: 840px; border-collapse: separate; border-spacing: 0; table-layout: fixed; }
.booking-table th, .booking-table td { border-top: 1px solid var(--line); border-right: 1px solid var(--line); }
.booking-table th:last-child, .booking-table td:last-child { border-right: 0; }
.booking-table th { position: sticky; top: 0; z-index: 4; height: 48px; padding: 0 10px; color: var(--navy); background: #f6faf9; font-size: 11px; text-align: left; }
.booking-table th:first-child { z-index: 5; width: 126px; }
.booking-table th small { display: block; margin-top: 2px; color: var(--muted); font-size: 8px; font-weight: 500; }
.booking-table td { height: 55px; padding: 5px; background: white; vertical-align: middle; }
.booking-table td.date-cell { position: sticky; left: 0; z-index: 3; width: 126px; padding: 8px 12px; background: #fbfdfc; }
.date-cell strong, .date-cell span { display: block; }
.date-cell strong { font-size: 11px; text-transform: capitalize; }
.date-cell span { margin-top: 2px; color: var(--muted); font-size: 9px; text-transform: capitalize; }
.booking-table tr.weekend td { background: #fcfaf6; }
.booking-table tr.weekend td.date-cell { background: #f9f5ec; }
.booking-table tr.today-row td { box-shadow: inset 0 1px #8acbc4, inset 0 -1px #8acbc4; }
.booking-table tr.today-row td.date-cell strong { color: var(--sea); }
.slot { width: 100%; min-height: 42px; padding: 6px 8px; border: 1px dashed #d4e2e0; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #91a4a5; background: #fbfdfd; font-size: 9px; font-weight: 700; text-transform: uppercase; transition: .15s ease; }
.slot:hover { border-color: var(--mint); color: var(--sea); background: var(--sea-soft); }
.slot.booked { position: relative; padding: 5px 22px 5px 8px; border-style: solid; border-color: #c1e3df; display: block; color: #185d5d; background: #e7f5f2; text-align: left; text-transform: none; overflow: hidden; }
.slot.booked.option { border-color: #ead7b5; color: #775621; background: #fff7e9; }
.slot.booked strong, .slot.booked small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.slot.booked strong { font-size: 10px; }
.slot.booked small { margin-top: 2px; color: inherit; opacity: .68; font-size: 8px; font-weight: 500; }
.slot .due-marker { position: absolute; top: 5px; right: 6px; width: 7px; height: 7px; border-radius: 50%; background: var(--danger); box-shadow: 0 0 0 2px white; }
.no-result { color: #b1bcbc !important; opacity: .35; }

.list-card { padding: 22px; }
.section-heading { margin-bottom: 18px; display: flex; align-items: center; justify-content: space-between; }
.section-heading h2 { margin: 5px 0 0; font: 800 25px Manrope, sans-serif; }
.booking-list { display: grid; gap: 9px; }
.booking-list-item { padding: 13px; border: 1px solid var(--line); border-radius: 11px; display: grid; grid-template-columns: 90px 1.3fr 1fr 1fr auto; align-items: center; gap: 14px; background: #fbfdfc; }
.booking-list-item span, .booking-list-item small { display: block; }
.booking-list-item strong { font-size: 12px; }
.booking-list-item span { color: var(--muted); font-size: 10px; }
.empty-state { padding: 50px 20px; color: var(--muted); text-align: center; }
.empty-state strong { display: block; margin-bottom: 5px; color: var(--ink); font: 800 17px Manrope, sans-serif; }
.fuel-toolbar { display: flex; gap: 9px; margin-bottom: 15px; }
.fuel-toolbar select { min-width: 150px; height: 40px; padding: 0 10px; border: 1px solid var(--line); border-radius: 9px; color: var(--ink); background: var(--paper); }
.fuel-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 18px; }
.fuel-entry { grid-template-columns: 105px 1.3fr 1fr 1fr auto; }
.settlement-toolbar { display: grid; grid-template-columns: repeat(3, minmax(150px, 220px)); gap: 10px; margin-bottom: 15px; padding: 13px; border-radius: 11px; background: var(--paper); }
.settlement-toolbar label { display: grid; gap: 5px; color: var(--muted); font-size: 10px; font-weight: 700; }
.settlement-toolbar select, .settlement-toolbar input { height: 40px; padding: 0 10px; border: 1px solid var(--line); border-radius: 9px; color: var(--ink); background: white; }
.settlement-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 20px; }
.settlement-summary .admin-stat small { display: block; margin-top: 4px; color: var(--muted); font-size: 9px; }
.highlight-stat { color: white; background: var(--sea) !important; }
.highlight-stat span, .highlight-stat small { color: rgba(255,255,255,.75) !important; }
.settlement-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.settlement-grid .admin-section:first-child { grid-column: 1 / -1; }
.settlement-row { padding: 11px 8px; border-top: 1px solid var(--line); display: grid; grid-template-columns: minmax(130px, 1.4fr) repeat(3, minmax(90px, 1fr)); align-items: center; gap: 10px; }
.settlement-row:first-child { border-top: 0; }
.settlement-row strong, .settlement-row span, .settlement-row small { display: block; }
.settlement-row strong { font-size: 11px; }
.settlement-row span, .settlement-row small { margin-top: 2px; color: var(--muted); font-size: 9px; }

.modal-backdrop { position: fixed; inset: 0; z-index: 50; padding: 24px; display: grid; place-items: center; background: rgba(5,32,38,.62); backdrop-filter: blur(5px); }
.modal { width: min(720px, 100%); max-height: calc(100vh - 48px); border-radius: 18px; background: white; box-shadow: 0 35px 90px rgba(4,32,39,.3); overflow: auto; }
.admin-modal { width: min(820px, 100%); }
.modal-header { position: sticky; top: 0; z-index: 3; padding: 18px 22px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,.96); backdrop-filter: blur(10px); }
.modal-header h2 { margin: 4px 0 0; font: 800 23px Manrope, sans-serif; letter-spacing: -.04em; }
.modal form { padding: 20px 22px 0; }
.form-grid { display: grid; gap: 13px; }
.form-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.modal label, .modal legend { display: block; color: #365b62; font-size: 10px; font-weight: 800; letter-spacing: .03em; text-transform: uppercase; }
.modal label input, .modal label select, .modal label textarea { margin-top: 6px; padding: 10px 11px; font-size: 12px; font-weight: 500; letter-spacing: 0; text-transform: none; resize: vertical; }
.modal label input:focus, .modal label select:focus, .modal label textarea:focus { border-color: var(--sea); box-shadow: 0 0 0 3px rgba(10,127,131,.08); }
.modal form > label, .modal form > fieldset, .modal .form-grid { margin-bottom: 14px; }
fieldset { margin-inline: 0; padding: 13px; border: 1px solid var(--line); border-radius: 11px; }
legend { padding: 0 6px; }
.location-options { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; margin-bottom: 11px; }
.radio-card, .check-label { padding: 10px; border: 1px solid var(--line); border-radius: 9px; display: flex !important; align-items: center; gap: 8px; background: #fbfdfc; cursor: pointer; }
.radio-card input, .check-label input { width: auto !important; margin: 0 !important; accent-color: var(--sea); }
.radio-card strong, .radio-card small, .check-label strong, .check-label small { display: block; letter-spacing: 0; text-transform: none; }
.radio-card strong, .check-label strong { color: var(--ink); font-size: 10px; }
.radio-card small, .check-label small { margin-top: 2px; color: var(--muted); font-size: 8px; font-weight: 500; }
.check-label { height: 62px; margin-top: 17px; }
.audit-info { margin: 4px 0 15px; padding: 11px 12px; border-radius: 9px; color: var(--muted); background: var(--paper); font-size: 10px; }
.audit-info strong { color: var(--ink); }
.modal-footer { position: sticky; bottom: 0; margin: 0 -22px; padding: 14px 22px; border-top: 1px solid var(--line); display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,.97); }
.footer-spacer { flex: 1; }
.admin-content { padding: 22px; }
.admin-filters { display: grid; grid-template-columns: repeat(5, minmax(120px, 1fr)) auto; gap: 8px; align-items: end; margin-bottom: 16px; padding: 13px; border-radius: 11px; background: var(--paper); }
.admin-filters label { display: grid; gap: 4px; color: var(--muted); font-size: 10px; font-weight: 700; }
.admin-filters input, .admin-filters select, .admin-row select { min-width: 0; height: 36px; padding: 0 8px; border: 1px solid var(--line); border-radius: 8px; color: var(--ink); background: white; font-size: 11px; }
.admin-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 20px; }
.admin-stat { padding: 14px; border-radius: 11px; background: var(--paper); }
.admin-stat span, .admin-stat strong { display: block; }
.admin-stat span { color: var(--muted); font-size: 9px; }
.admin-stat strong { margin-top: 5px; font: 800 18px Manrope, sans-serif; }
.admin-section { margin-top: 18px; }
.admin-section h3 { margin: 0 0 10px; font: 800 15px Manrope, sans-serif; }
.admin-row { padding: 10px; border-top: 1px solid var(--line); display: flex; align-items: center; gap: 8px; }
.admin-row:first-child { border-top: 0; }
.admin-row > span { flex: 1; font-size: 12px; }
.admin-row > span small { display: block; margin-top: 2px; color: var(--muted); }
.inline-form { padding: 13px; border-radius: 11px; display: grid; grid-template-columns: 1fr 1fr auto; gap: 8px; background: var(--paper); }
#add-user-form { grid-template-columns: 1fr 1fr 1fr auto; }
.inline-form input, .inline-form select { min-width: 0; height: 40px; padding: 0 9px; border: 1px solid var(--line); border-radius: 8px; background: white; font-size: 11px; }
.bar-row { margin-bottom: 10px; }
.bar-label { margin-bottom: 4px; display: flex; justify-content: space-between; font-size: 10px; }
.bar-track { height: 7px; border-radius: 10px; background: var(--paper); overflow: hidden; }
.bar-track i { height: 100%; display: block; border-radius: inherit; background: var(--sea); }
.data-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.notice { margin-bottom: 15px; padding: 11px; border: 1px solid #ead7b5; border-radius: 9px; color: #795b2d; background: #fff8ec; font-size: 10px; line-height: 1.5; }
.toast { position: fixed; right: 22px; bottom: 22px; z-index: 100; max-width: 330px; padding: 12px 16px; border-radius: 10px; color: white; background: var(--navy); box-shadow: var(--shadow); font-size: 12px; font-weight: 700; }
.mobile-only { display: none; }

@media (max-width: 1050px) {
  .sidebar { width: 70px; padding-inline: 10px; }
  .side-brand div:last-child, .side-nav .nav-item:not(.active) { display: none; }
  .side-brand { justify-content: center; padding-inline: 0; }
  .side-brand-logo { width: 52px; }
  .side-nav .nav-item { justify-content: center; padding-inline: 0; font-size: 0; }
  .side-bottom { display: none; }
  .main { margin-left: 70px; }
  .calendar-toolbar { align-items: stretch; flex-direction: column; }
  .filters .search-field { width: 100%; }
  .summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .login-screen { display: block; background: var(--paper); }
  .login-art { min-height: auto; padding: 24px; }
  .login-message { padding: 80px 0 10px; }
  .login-message h2 { font-size: 38px; }
  .login-panel { padding: 34px 22px 70px; }
  .sidebar { display: none; width: 225px; }
  .sidebar.open { display: flex; z-index: 40; width: min(280px, 88vw); box-shadow: 20px 0 50px rgba(4,32,39,.35); }
  .sidebar.open .mobile-close-menu { display: block; }
  .sidebar.open .side-brand div:last-child { display: block; }
  .sidebar.open .side-nav .nav-item { display: flex; justify-content: flex-start; padding: 12px 13px; font-size: 13px; }
  .sidebar.open .side-bottom { display: block; }
  .main { margin-left: 0; }
  .topbar { height: auto; min-height: 76px; padding: 13px 16px; gap: 10px; }
  .topbar > div:first-child { display: flex; align-items: center; gap: 9px; }
  .topbar .eyebrow, .user-chip span:nth-child(2), .user-chip b { display: none; }
  .topbar h1 { font-size: 17px; }
  .mobile-only { display: block; }
  #quick-add { width: 42px; padding: 0; font-size: 0; }
  #quick-add span { font-size: 20px; }
  .content-view { padding: 15px; }
  .summary-grid { grid-template-columns: 1fr; }
  .summary-card { min-height: 66px; }
  .month-switcher { flex-wrap: wrap; }
  .filters { flex-direction: column; align-items: stretch; }
  .filters select { width: 100%; }
  .legend { overflow-x: auto; white-space: nowrap; }
  .calendar-scroll { max-height: calc(100vh - 470px); }
  .form-grid.two, .location-options { grid-template-columns: 1fr; }
  .check-label { margin-top: 0; }
  .modal-backdrop { padding: 0; place-items: end center; }
  .modal { width: 100%; max-height: 94vh; border-radius: 18px 18px 0 0; }
  .modal-footer { flex-wrap: wrap; }
  .admin-grid { grid-template-columns: 1fr 1fr; }
  .admin-filters { grid-template-columns: 1fr; }
  .inline-form { grid-template-columns: 1fr; }
  #add-user-form { grid-template-columns: 1fr; }
  .booking-list-item { grid-template-columns: 1fr auto; }
  .fuel-toolbar { flex-direction: column; }
  .fuel-toolbar select { width: 100%; }
  .fuel-summary { grid-template-columns: 1fr; }
  .settlement-toolbar, .settlement-summary, .settlement-grid { grid-template-columns: 1fr; }
  .settlement-grid .admin-section:first-child { grid-column: auto; }
  .settlement-row { grid-template-columns: 1fr 1fr; }
}
