/* ========================================
   Floosy Finance App Design System
   ======================================== */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap");

/* ========================================
   CSS Variables - Floosy Design System
   ======================================== */
:root {
  /* Site Blue Color Template */
  --color-primary: #00677f;
  --color-primary-dark: #008099;
  --color-primary-light: #b8dce4;
  --color-secondary: #4a6b7c;
  
  /* Background Colors (blue-tinted neutrals) */
  --bg-page: #f0f4f6;
  --bg-sidebar: #ffffff;
  --bg-card: #ffffff;
  --bg-hover: #e8eef2;
  --bg-active: #b8dce4;
  --bg-mobile-nav: #ffffff;
  
  /* Text Colors */
  --text-primary: #1e3a47;
  --text-secondary: #4a6b7c;
  --text-muted: #7a9cad;
  --text-on-primary: #ffffff;
  --text-mobile-nav: #4a6b7c;

  /* Borders - none (transparent); subtle for inputs/options */
  --border-light: transparent;
  --border-medium: transparent;
  --border-subtle: rgba(0, 103, 127, 0.18);
  --border-focus: #00677f;

  /* Status Colors (blue-aligned) */
  --color-success: #0d9488;
  --color-warning: #d97706;
  --color-danger: #dc2626;
  --color-info: #00677f;

  /* Spacing Scale (4px base) */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;

  /* Border Radius */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Shadows - Subtle and clean */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.03);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.05);
  --shadow-md:
    0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg:
    0 10px 15px -3px rgba(0, 0, 0, 0.05), 0 4px 6px -4px rgba(0, 0, 0, 0.05);
  --shadow-xl:
    0 20px 25px -5px rgba(0, 0, 0, 0.05), 0 8px 10px -6px rgba(0, 0, 0, 0.05);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-normal: 200ms ease;
  --transition-slow: 300ms ease;

  /* Layout */
  --sidebar-width: 280px;
  --sidebar-collapsed: 70px;
  --header-height: 72px;

  /* Typography - Floosy Style */
  --font-sans:
    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono: "JetBrains Mono", "Fira Code", monospace;
  
  /* Floosy Font Sizes */
  --font-size-xs: 0.875rem;
  --font-size-sm: 1rem;
  --font-size-base: 1.125rem;
  --font-size-lg: 1.25rem;
  --font-size-xl: 1.375rem;
  --font-size-2xl: 1.625rem;
  --font-size-3xl: 2.125rem;
  
  /* Floosy Font Weights */
  --font-weight-medium: 600;
  --font-weight-semibold: 700;
  --font-weight-bold: 800;
  --font-weight-extrabold: 900;
  --font-weight-black: 900;
}

/* ========================================
   Base Reset & Global Styles
   ======================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-sans);
  background-color: var(--bg-page);
  color: var(--text-primary);
  line-height: 1.5;
  min-height: 100vh;
  overflow-x: hidden;
}

/* ========================================
   App Layout Structure
   ======================================== */
.app-layout {
  display: flex;
  min-height: 100vh;
  width: 100%;
}

/* ========================================
   Sidebar
   ======================================== */
.sidebar {
  width: var(--sidebar-width);
  background: var(--bg-sidebar);
  border-right: none;
  display: flex;
  flex-direction: column;
  position: fixed;
  left: 0;
  top: 0;
  height: 100vh;
  z-index: 100;
  transition:
    width var(--transition-slow),
    transform var(--transition-slow);
}

.sidebar-header {
  padding: var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  border-bottom: none;
  height: var(--header-height);
  flex-shrink: 0;
}

.sidebar-logo {
  width: 40px;
  height: 40px;
  background: var(--color-primary);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0, 103, 127, 0.25);
}

.sidebar-title {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.sidebar-title-main {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
}

.sidebar-title-sub {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.sidebar-nav {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  overflow-y: auto;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
}

.nav-link:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.nav-link.active {
  background: var(--bg-active);
  color: var(--color-primary);
  border-radius: var(--radius-lg);
  font-weight: var(--font-weight-semibold);
  box-shadow: 0 2px 8px rgba(0, 103, 127, 0.2);
}

.nav-icon {
  font-size: 1.25rem;
  width: 28px;
  text-align: center;
  flex-shrink: 0;
}

.nav-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Sidebar Collapsed State (Desktop) */
.sidebar-collapsed {
  width: var(--sidebar-collapsed);
}

.sidebar-collapsed .sidebar-title,
.sidebar-collapsed .nav-label {
  opacity: 0;
  width: 0;
  overflow: hidden;
}

.sidebar-collapsed .nav-link {
  justify-content: center;
  padding: var(--space-3);
}

.sidebar-collapsed .nav-icon {
  margin: 0;
}

/* Car Name Button */
.car-name-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  text-align: left;
  cursor: pointer;
  /* display: flex;
  flex-direction: column;
  gap: var(--space-1); */
  transition: all var(--transition-fast);
  width: 100%;
}

.car-name-btn:hover .sidebar-title-main {
  color: var(--color-primary);
}

/* Mobile adjustments for car name */
@media (max-width: 991px) {
  .sidebar-header {
    padding: var(--space-3) var(--space-5);
    height: auto;
  }

  .car-name-btn {
    gap: 0;
    margin-bottom: 0px;
  }

  .sidebar-title {
    margin-bottom: 0;
    line-height: 1;
  }

  .sidebar-title-main {
    margin-bottom: 0;
  }

  .sidebar-title-sub {
    margin-top: 0px;
  }
}

/* ========================================
   Sidebar Header Icons
   ======================================== */
.sidebar-logo .fa-car {
  color: #ffffff;
  font-size: 1.5rem;
}

/* ========================================
   Navigation Icons
   ======================================== */
.nav-icon .fa-home {
  color: var(--text-secondary);
}

.nav-link.active .fa-home {
  color: var(--color-primary);
}

.nav-icon .fa-chart-bar {
  color: var(--text-secondary);
}

.nav-link.active .fa-chart-bar {
  color: var(--color-primary);
}

.nav-icon .fa-gas-pump {
  color: var(--text-secondary);
}

.nav-link.active .fa-gas-pump {
  color: var(--color-primary);
}

.nav-icon .fa-edit {
  color: var(--text-secondary);
}

.nav-link.active .fa-edit {
  color: var(--color-primary);
}

.nav-icon .fa-cog {
  color: var(--text-secondary);
}

.nav-link.active .fa-cog {
  color: var(--color-primary);
}

/* ========================================
   Icon Colors
   ======================================== */
/* Edit buttons */
.edit-car-info-btn .fa-edit {
  color: var(--text-muted);
}

.edit-car-info-btn:hover .fa-edit {
  color: var(--color-primary);
}

/* Category action buttons */
.category-edit-btn .fa-edit {
  color: var(--text-secondary);
}

.category-edit-btn:hover .fa-edit {
  color: var(--color-primary);
}

.category-delete-btn .fa-trash {
  color: var(--text-secondary);
}

.category-delete-btn:hover .fa-trash {
  color: var(--color-danger);
}

/* Pagination arrows */
.pagination-btn .fa-chevron-left,
.pagination-btn .fa-chevron-right {
  color: var(--text-secondary);
}

.pagination-btn:hover .fa-chevron-left,
.pagination-btn:hover .fa-chevron-right {
  color: var(--color-primary);
}

/* Clear search button */
.clear-search-btn .fa-times {
  color: var(--text-muted);
}

.clear-search-btn:hover .fa-times {
  color: var(--color-danger);
}

/* Modal close buttons */
.close .fa-times,
.popup-close .fa-times {
  color: var(--text-muted);
}

.close:hover .fa-times,
.popup-close:hover .fa-times {
  color: var(--text-secondary);
}

/* Warning icon */
.warning-text .fa-exclamation-triangle {
  color: var(--color-warning);
  margin-right: var(--space-2);
}

/* Empty state icons */
.empty-icon .fa-gas-pump {
  color: var(--text-muted);
  font-size: 3rem;
  margin-bottom: var(--space-3);
}

/* Session card buttons */
.edit-btn .fa-edit {
  color: var(--text-secondary);
}

.edit-btn:hover .fa-edit {
  color: var(--color-secondary);
}

.delete-btn .fa-trash {
  color: var(--text-secondary);
}

.delete-btn:hover .fa-trash {
  color: var(--color-danger);
}

/* Upcoming item buttons */
.mark-done-btn .fa-check {
  color: var(--text-secondary);
}

.mark-done-btn:hover .fa-check {
  color: var(--color-success);
}

.edit-upcoming-btn .fa-edit {
  color: var(--text-secondary);
}

.edit-upcoming-btn:hover .fa-edit {
  color: var(--color-primary);
}

.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 99;
  opacity: 0;
  transition: opacity var(--transition-normal);
  pointer-events: none;
}

.mobile-overlay.active {
  display: block;
  opacity: 1;
  pointer-events: auto;
}

/* ========================================
   Main Area
   ======================================== */
.main-area {
  flex: 1;
  margin-left: var(--sidebar-width);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  transition: margin-left var(--transition-slow);
}

.main-area.sidebar-collapsed {
  margin-left: var(--sidebar-collapsed);
}

/* ========================================
   Header
   ======================================== */
header {
  height: var(--header-height);
  background: var(--bg-sidebar);
  border-bottom: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-6);
  position: sticky;
  top: 0;
  z-index: 50;
}

.header-left {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.header-right {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.sidebar-toggle-btn {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  cursor: pointer;
  gap: 4px;
  transition: all var(--transition-fast);
}

.sidebar-toggle-btn:hover {
  background: var(--bg-hover);
  border-color: var(--border-medium);
}

.hamburger-line {
  width: 18px;
  height: 2px;
  background: var(--text-secondary);
  border-radius: 1px;
  transition: all var(--transition-normal);
}

header h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-primary);
}

/* ========================================
   Main Content
   ======================================== */
main {
  flex: 1;
  padding: var(--space-6);
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}

/* ========================================
   Section Styling
   ======================================== */
section {
  margin-bottom: var(--space-8);
}

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

section h2 {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

section h2::before {
  content: "";
  width: 3px;
  height: 18px;
  background: var(--color-primary);
  border-radius: 2px;
}

/* ========================================
   Panel Content (Card Container)
   ======================================== */
.panel-content {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-light);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

/* ========================================
   KPI Row Layout (Digital ID + KPIs on same line)
   ======================================== */
.kpis-row {
  display: flex;
  gap: var(--space-4);
  align-items: stretch;
}

.kpi-digital-id {
  flex: 2;
  min-width: 0;
}

.kpi-cards-group {
  flex: 3;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

/* ========================================
   KPI Cards
   ======================================== */
.kpi-card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: none;
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-height: 140px;
  transition: all var(--transition-fast);
}

.kpi-card:hover {
  box-shadow: var(--shadow-md);
  border: none;
}

.kpi-label {
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.kpi-main {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-primary);
}

.kpi-sub {
  font-size: 1rem;
  color: var(--text-muted);
}

.kpi-odo-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.kpi-odo-btn:hover .kpi-main {
  color: var(--color-primary);
}

/* Car Info Card Specific */
.car-info-card {
  position: relative;
}

.edit-car-info-btn {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 32px;
  height: 32px;
  background: var(--bg-hover);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  z-index: 1;
}

.edit-car-info-btn:hover {
  background: whitesmoke;
  border-color: var(--color-primary);
  color: white;
}

.car-info-header {
  margin-bottom: var(--space-4);
}

.live-time {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--text-muted);
}

.car-info-body {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
}

@media (max-width: 768px) {
  .car-info-body {
    flex-direction: column;
    gap: var(--space-3);
  }

  .license-expiry-box {
    order: 1;
    width: 100%;
    min-width: auto;
  }

  .car-info-main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    grid-auto-flow: column;
    gap: var(--space-2) var(--space-4);
    order: 2;
  }

  .car-info-item {
    gap: var(--space-1);
  }

  .car-info-item:nth-child(1) { grid-row: 1; grid-column: 1; }
  .car-info-item:nth-child(2) { grid-row: 2; grid-column: 1; }
  .car-info-item:nth-child(3) { grid-row: 1; grid-column: 2; }
  .car-info-item:nth-child(4) { grid-row: 2; grid-column: 2; }
}

.car-info-main {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3) var(--space-6);
  flex: 1;
}

.car-info-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.car-info-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.car-info-value {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text-primary);
}

.license-expiry-box {
  background: #f2f2f3bf;
  border: 0px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 140px;
  box-shadow: var(--shadow-sm);
}

.license-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.license-value {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
}

/* License warning states */
.license-expiry-box.license-warning-soon {
  background: rgba(245, 158, 11, 0.1);
  border-color: var(--color-warning);
}

.license-expiry-box.license-warning-urgent {
  background: rgba(239, 68, 68, 0.1);
  border-color: var(--color-danger);
}

.license-expiry-box.license-warning-expired {
  background: rgba(239, 68, 68, 0.15);
  border-color: var(--color-danger);
}

/* ========================================
   Home Content Grid (Two-column layout)
   ======================================== */
.home-content-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

.home-content-grid section {
  margin-bottom: 0;
}

/* ========================================
   Search & Filter Controls
   ======================================== */
.search-controls {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.search-group {
  position: relative;
}

.search-group input {
  width: 100%;
  padding: var(--space-3) var(--space-10) var(--space-3) var(--space-4);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  transition: all var(--transition-fast);
  background: var(--bg-card);
}

.search-group input:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(0, 103, 127, 0.15);
}

.clear-search-btn {
  position: absolute;
  right: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--space-1);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.clear-search-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.filter-group {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.filter-group select {
  flex: 1;
  min-width: 150px;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  background: var(--bg-card);
  color: var(--text-primary);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.filter-group select:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(0, 103, 127, 0.15);
}

/* ========================================
   Session Cards
   ======================================== */
.sessions-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

#sessionsList {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.session-card {
  background: #e4ebf3a9;
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  position: relative;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.session-card:hover {
  border: none;
  box-shadow: var(--shadow-md);
  background: #f1f5f9;
}

.session-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-3);
  padding-right: 80px;
}

.session-header-main {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.session-header h3 {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.time-context {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.time-context-neutral {
  color: var(--text-muted);
}

.time-context-warning {
  color: var(--color-warning);
  font-weight: 500;
}

.time-context-critical {
  color: var(--color-danger);
  font-weight: 500;
}

.edit-btn,
.delete-btn {
  position: absolute;
  top: var(--space-4);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
  font-size: 1rem;
}

.edit-btn {
  right: 48px;
  color: var(--color-primary);
}

.delete-btn {
  right: var(--space-4);
  color: var(--color-danger);
}

.edit-btn:hover,
.delete-btn:hover {
  background: var(--bg-hover);
}

.session-card p {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}

.session-card p strong {
  color: var(--text-primary);
  font-weight: 500;
}

.session-card hr {
  border: none;
  border-top: 1px solid var(--border-light);
  margin: var(--space-3) 0;
}

.item-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.item-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) 0;
  font-size: 0.875rem;
  font-weight: 400;
}

.item-row span:first-child {
  color: var(--text-secondary);
  font-weight: 500;
}

.item-row span:last-child {
  color: var(--text-primary);
  font-weight: 600;
}

.category-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-md);
  font-size: 0.6875rem;
  font-weight: 600;
  color: #ffffff !important;
  margin-left: var(--space-2);
  background: var(--color-primary);
}

.session-total {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-light);
  text-align: right;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-primary);
}

.hidden-items-container {
  display: none;
}

.hidden-items-container[style*="block"] {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.show-more-items {
  width: 100%;
  padding: var(--space-2);
  margin-top: var(--space-2);
  background: var(--bg-hover);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.show-more-items:hover {
  background: var(--bg-active);
  color: var(--text-primary);
}

/* ========================================
   Upcoming Maintenance
   ======================================== */
.upcoming-maintenance-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

#upcomingList {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.upcoming-item {
  background: #e4ebf3a9;
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  transition: all var(--transition-fast);
}

.upcoming-item:hover {
  border: none;
  box-shadow: var(--shadow-sm);
  background: #f1f5f9;
}

.upcoming-content {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
  position: relative;
}

.upcoming-info {
  flex: 1;
}

.item-header-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  flex-wrap: wrap;
}

.item-name {
  font-weight: 600;
  color: var(--text-primary);
}

.urgency-badge {
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  flex-shrink: 0;
  align-self: center;
}

.urgency-badge.status-ok {
  background: rgba(16, 185, 129, 0.1);
  color: var(--color-success);
}

.urgency-badge.status-caution {
  background: rgba(245, 158, 11, 0.1);
  color: var(--color-warning);
}

.urgency-badge.status-warning {
  background: rgba(239, 68, 68, 0.1);
  color: var(--color-danger);
}

.urgency-badge.status-danger {
  background: rgba(239, 68, 68, 0.15);
  color: var(--color-danger);
  animation: pulse 2s infinite;
}

@keyframes pulse {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.7;
  }
}

.item-details {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.km-info,
.next-due {
  font-size: 0.8125rem;
  color: var(--text-secondary);
}

.upcoming-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.mark-done-btn,
.edit-upcoming-btn {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.mark-done-btn {
  background: var(--color-success);
  color: white;
}

.mark-done-btn:hover {
  background: #059669;
}

.edit-upcoming-btn {
  background: var(--bg-hover);
  color: var(--text-secondary);
}

.edit-upcoming-btn:hover {
  background: var(--border-light);
  color: var(--text-primary);
}

.progress-container {
  height: 8px;
  background: var(--bg-hover);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress-bar {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width var(--transition-slow);
  position: relative;
}

.progress-label {
  display: none;
}

.no-upcoming {
  text-align: center;
  padding: var(--space-10);
  color: var(--text-muted);
}

.no-upcoming-icon {
  font-size: 2.5rem;
  margin-bottom: var(--space-3);
}

.no-upcoming-text {
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-secondary);
}

/* Completed Items */
.completed-item {
  background: var(--bg-hover);
  border: none;
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
}

.completed-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.completed-info .item-name {
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.interval-info {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.completed-actions {
  display: flex;
  gap: var(--space-2);
}

.restore-btn,
.delete-completed-btn {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  transition: all var(--transition-fast);
}

.restore-btn {
  background: var(--text-secondary);
  color: white;
}

.restore-btn:hover {
  background: var(--color-primary);
}

.delete-completed-btn {
  background: var(--color-danger);
  color: white;
}

.delete-completed-btn:hover {
  background: #dc2626;
}

/* ========================================
   Pagination
   ======================================== */
.pagination-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--bg-hover);
  border-radius: var(--radius-lg);
  margin-top: var(--space-4);
}

.pagination-btn {
  padding: var(--space-2) var(--space-4);
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.pagination-btn:hover:not(:disabled) {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: white;
}

.pagination-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.page-info {
  font-size: 0.875rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* ========================================
   Charts Section
   ======================================== */
.charts-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}

.chart-card {
  background: var(--bg-card);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

.chart-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-4);
}

.chart-card canvas {
  width: 100% !important;
  height: 300px !important;
}

.chart-controls {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.chart-btn {
  padding: var(--space-2) var(--space-4);
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.chart-btn:hover {
  border-color: var(--border-medium);
  color: var(--text-primary);
}

.chart-btn.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: white;
}

.chart-filter-select {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  background: var(--bg-card);
  color: var(--text-primary);
  cursor: pointer;
}

.chart-empty-message {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 300px;
  color: var(--text-muted);
  font-size: 0.9375rem;
}

/* ========================================
   Fuel Analytics
   ======================================== */
.fuel-kpis-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.fuel-kpi-card {
  background: var(--bg-card);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  text-align: center;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 120px;
}

.fuel-kpi-label {
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: var(--space-1);
}

.fuel-kpi-main {
  font-size: 2.75rem;
  font-weight: 800;
  color: var(--text-primary);
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fuel-kpi-sub {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-muted);
  margin-top: auto;
}

.fuel-chart-card {
  margin-bottom: var(--space-5);
}

.fuel-chart-card:last-child {
  margin-bottom: 0;
}

/* ========================================
   Record Form
   ======================================== */
.record-section .form-group {
  margin-bottom: var(--space-4);
}

.form-group label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

/* Styled Input - Applied to all inputs */
.styled-input,
.form-group input[type="text"],
.form-group input[type="number"],
.form-group input[type="date"],
.form-group textarea,
.form-group select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  background: var(--bg-card);
  color: var(--text-primary);
  transition: all var(--transition-fast);
  font-family: var(--font-sans);
}

.styled-input:focus,
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(0, 103, 127, 0.15);
}

.form-group textarea {
  resize: vertical;
  min-height: 80px;
}

.items-section-title {
  margin: var(--space-6) 0 var(--space-4);
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
}

/* Item Form */
.item-form {
  background: var(--bg-hover);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
  position: relative;
}

.item-inputs {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.item-inputs input,
.item-notes input,
.item-notes select,
.item-notes textarea {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  background: var(--bg-card);
  color: var(--text-primary);
  transition: all var(--transition-fast);
}

.item-inputs input:focus,
.item-notes input:focus,
.item-notes select:focus,
.item-notes textarea:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(0, 103, 127, 0.15);
}

.item-notes {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-3);
}

.delete-item-btn {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  width: 24px;
  height: 24px;
  background: var(--color-danger);
  color: white;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.delete-item-btn:hover {
  background: #dc2626;
}

/* ========================================
   Buttons
   ======================================== */
.primary-btn {
  padding: var(--space-3) var(--space-6);
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.primary-btn:hover {
  background: var(--color-primary-dark);
}

.primary-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.secondary-btn {
  padding: var(--space-3) var(--space-6);
  background: var(--bg-hover);
  color: var(--text-primary);
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.secondary-btn:hover {
  background: var(--bg-active);
  color: var(--text-primary);
}

.small-btn {
  padding: var(--space-2) var(--space-4);
  background: var(--bg-hover);
  color: var(--text-secondary);
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.small-btn:hover {
  background: var(--bg-active);
  color: var(--text-primary);
}

.danger-btn {
  padding: var(--space-3) var(--space-6);
  background: var(--color-danger);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.danger-btn:hover {
  background: #dc2626;
}

.actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-6);
}

/* ========================================
   Settings Page
   ======================================== */
.settings-page {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}

.settings-section {
  background: var(--bg-card);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

.settings-section h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-light);
}

.settings-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.help-text {
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin-top: var(--space-1);
}

.warning-text {
  font-size: 0.8125rem;
  color: var(--color-danger);
  padding: var(--space-3);
  background: rgba(239, 68, 68, 0.05);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-danger);
}

/* Data Management Combined Section */
.data-management-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.danger-divider {
  border: none;
  border-top: 1px solid var(--border-light);
  margin: var(--space-2) 0;
}

.data-management-group .danger-btn {
  margin-top: var(--space-1);
}

.data-management-group .warning-text {
  margin-top: var(--space-1);
  font-size: 0.75rem;
}

/* Categories List */
.categories-list {
  margin-top: var(--space-4);
  max-height: 300px;
  overflow-y: auto;
}

.category-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-3) var(--space-4);
  background: var(--bg-hover);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  transition: all var(--transition-fast);
}

.category-item:hover {
  background: var(--border-light);
}

.category-info {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.category-color {
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
}

.category-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-primary);
}

.category-actions {
  display: flex;
  gap: var(--space-2);
}

.category-edit-btn,
.category-delete-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  transition: all var(--transition-fast);
}

.category-edit-btn {
  color: var(--color-primary);
}

.category-edit-btn:hover {
  background: rgba(0, 103, 127, 0.1);
}

.category-delete-btn {
  color: var(--color-danger);
}

.category-delete-btn:hover {
  background: rgba(239, 68, 68, 0.1);
}

/* ========================================
   Category Edit Popup
   ======================================== */
.popup-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 300;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  backdrop-filter: blur(4px);
}

.popup-overlay.active {
  display: flex;
}

.popup-card {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  width: 100%;
  max-width: 400px;
  box-shadow: var(--shadow-xl);
  animation: popupSlideIn 0.2s ease;
}

@keyframes popupSlideIn {
  from {
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.popup-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-5);
}

.popup-header h3 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.popup-close {
  width: 32px;
  height: 32px;
  background: var(--bg-hover);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--text-muted);
  transition: all var(--transition-fast);
}

.popup-close:hover {
  background: var(--border-light);
  color: var(--text-primary);
}

.popup-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.popup-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-6);
}

/* ========================================
   Modals
   ======================================== */
.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 200;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.modal[style*="flex"] {
  display: flex;
}

.modal-content {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  box-shadow: var(--shadow-xl);
}

.small-modal {
  max-width: 400px;
}

.close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-size: 1.5rem;
  color: var(--text-muted);
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.close:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.modal-content h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-5);
}

/* Session Details Modal */
.session-details {
  max-height: 60vh;
  overflow-y: auto;
}

.detail-section {
  margin-bottom: var(--space-5);
}

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

.detail-section h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-3);
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}

.detail-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.detail-item.full-width {
  grid-column: 1 / -1;
}

.detail-item label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.detail-item span {
  font-size: 0.9375rem;
  color: var(--text-primary);
}

.items-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.item-detail-card {
  background: var(--bg-hover);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.item-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-3);
}

.item-header h4 {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
}

.item-price {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-primary);
}

.session-total-details {
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: var(--color-primary);
  color: white;
  border-radius: var(--radius-md);
  text-align: center;
  font-size: 1.125rem;
  font-weight: 600;
  box-shadow: var(--shadow-md);
}

/* ========================================
   Floating Buttons
   ======================================== */
.floating-btn {
  position: fixed;
  right: var(--space-6);
  bottom: var(--space-6);
  width: 56px;
  height: 56px;
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--radius-full);
  font-size: 1.5rem;
  cursor: pointer;
  box-shadow: var(--shadow-lg);
  transition: all var(--transition-fast);
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: center;
}

.floating-btn:hover {
  background: var(--color-primary-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

.floating-btn.secondary {
  right: calc(var(--space-6) + 64px);
  background: var(--text-secondary);
}

.floating-btn.secondary:hover {
  background: var(--text-primary);
}

body.modal-open .floating-btn {
  display: none;
}

body.modal-open {
  overflow: hidden;
}

/* ========================================
   Status Indicators
   ======================================== */
.status-ok {
  color: var(--color-success);
}

.status-warning {
  color: var(--color-warning);
}

.status-danger {
  color: var(--color-danger);
}

/* ========================================
   FUEL ANALYTICS SYSTEM STYLES
   ======================================== */

/* Fuel Entry Form */
.fuel-entry-section .form-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.fuel-entry-section .form-group {
  margin-bottom: 0;
}

.fuel-entry-section input[readonly] {
  background: var(--bg-hover);
  color: var(--text-secondary);
  cursor: not-allowed;
}

/* Full Tank Checkbox - Modern Design */
.fuel-form-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
}

/* Inline Actions Row - Checkboxes and Save Button on Same Line */
.inline-actions-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: var(--space-4) !important;
  margin-bottom: var(--space-4) !important;
}

.inline-checkboxes {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: var(--space-4) !important;
  margin-bottom: 0 !important;
}

.inline-actions {
  display: flex !important;
  justify-content: flex-end !important;
  margin-top: var(--space-2) !important;
  margin-bottom: var(--space-2) !important;
}

.full-tank-group {
  padding-top: var(--space-2);
}

.checkbox-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
}

.checkbox-wrapper .checkbox-label {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
}

.checkbox-wrapper .help-text {
  margin-left: 0;
  padding-left: 0;
  margin-top: 0;
}

.checkbox-label {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  font-size: 0.875rem;
  color: var(--text-primary);
  font-weight: 500;
  user-select: none;
  white-space: nowrap;
  flex-wrap: nowrap;
}

/* Input with clear button */
.input-with-clear {
  position: relative;
  display: flex;
  align-items: center;
}

.input-with-clear input {
  width: 100%;
  padding-right: 40px;
}

.input-with-clear input[type="number"] {
  padding-right: 40px;
  /* Hide spinners */
  -moz-appearance: textfield;
  appearance: textfield;
}

.input-with-clear input[type="number"]::-webkit-outer-spin-button,
.input-with-clear input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.clear-input-btn {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--space-1);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  font-size: 0.75rem;
  transition: all var(--transition-fast);
  z-index: 2;
}

.clear-input-btn:hover {
  background: var(--bg-hover);
  color: var(--color-danger);
}

/* Mobile clear button */
@media only screen and (max-width: 768px) {
  .clear-input-btn {
    width: 28px;
    height: 28px;
    font-size: 0.8rem;
    right: 6px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    padding: var(--space-1);
  }

  .input-with-clear input {
    padding-right: 40px;
  }
}

.checkbox-label input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  width: 0;
  height: 0;
}

.checkmark {
  width: 20px;
  height: 20px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  flex-shrink: 0;
}

.checkmark::after {
  content: "✓";
  color: white;
  font-size: 12px;
  font-weight: bold;
  opacity: 0;
  transform: scale(0.5);
  transition: all var(--transition-fast);
}

.checkbox-label input[type="checkbox"]:checked + .checkmark {
  background: var(--color-success);
  border-color: var(--color-success);
}

.checkbox-label input[type="checkbox"]:checked + .checkmark::after {
  opacity: 1;
  transform: scale(1);
}

.checkbox-label:hover .checkmark {
  border-color: var(--color-primary);
}

.full-tank-text,
.fund-deduction-text {
  white-space: nowrap;
  flex-shrink: 0;
}

/* Form Errors and Success Messages */
.form-errors {
  margin-bottom: var(--space-4);
}

.error-message {
  padding: var(--space-3) var(--space-4);
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid var(--color-danger);
  border-radius: var(--radius-md);
  color: var(--color-danger);
  font-size: 0.875rem;
}

.success-message {
  padding: var(--space-3) var(--space-4);
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid var(--color-success);
  border-radius: var(--radius-md);
  color: var(--color-success);
  font-size: 0.875rem;
}

/* Fuel History List */
.fuel-history-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.fuel-history-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
}

.fuel-history-item:hover {
  border-color: var(--border-medium);
  box-shadow: var(--shadow-sm);
}

.fuel-history-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-2);
  padding-right: 80px;
  position: relative;
}

.fuel-history-header-main {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.fuel-history-header .date {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
}

.fuel-history-header .edit-btn,
.fuel-history-header .delete-btn {
  position: absolute;
  top: 0;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
  font-size: 1rem;
}

.fuel-history-header .edit-btn {
  right: 48px;
  color: var(--color-primary);
}

.fuel-history-header .delete-btn {
  right: var(--space-4);
  color: var(--color-danger);
}

.fuel-history-header .edit-btn:hover,
.fuel-history-header .delete-btn:hover {
  background: var(--bg-hover);
}

.fuel-history-details {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  color: var(--text-muted);
  font-size: 0.875rem;
}

.fuel-history-cost {
  text-align: right;
  font-weight: 600;
  color: var(--color-primary);
}

.fuel-history-date .date {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
}

.full-tank-badge {
  background: var(--color-success);
  color: white;
  padding: 2px var(--space-2);
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.fuel-history-details {
  display: flex;
  gap: var(--space-4);
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.fuel-history-details span {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.fuel-history-cost {
  text-align: right;
  padding: 0 var(--space-4);
}

.fuel-history-details .total {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-primary);
}

.fuel-history-actions {
  display: flex;
  gap: var(--space-2);
}

.fuel-history-actions .edit-btn,
.fuel-history-actions .delete-btn {
  width: 32px;
  height: 32px;
  background: var(--bg-hover);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  font-size: 0.875rem;
}

.fuel-history-actions .edit-btn {
  color: var(--color-primary);
}

.fuel-history-actions .edit-btn:hover {
  background: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
}

.fuel-history-actions .delete-btn {
  color: var(--color-danger);
}

.fuel-history-actions .delete-btn:hover {
  background: var(--color-danger);
  color: white;
  border-color: var(--color-danger);
}

/* Empty State */
.empty-state {
  text-align: center;
  padding: var(--space-10);
  color: var(--text-muted);
}

.empty-state .empty-icon {
  font-size: 3rem;
  margin-bottom: var(--space-3);
}

.empty-state p {
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: var(--space-1);
}

.empty-state span {
  font-size: 0.875rem;
}

.empty-text {
  text-align: center;
  padding: var(--space-6);
  color: var(--text-muted);
  font-size: 0.9375rem;
}

/* Last Refill Card */
.last-refill-card {
  background: var(--bg-hover);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.last-refill-card .refill-date {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

.last-refill-card .refill-details {
  display: flex;
  gap: var(--space-4);
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}

.last-refill-card .refill-cost {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-primary);
}

/* Last Refill KPI Card Styles */
.fuel-kpi-last-refill .fuel-kpi-main {
  font-size: 1rem;
  text-align: center;
  display: block;
  flex: none;
}

.last-refill-kpi-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: center;
  text-align: center;
}

.last-refill-kpi-content .last-refill-date {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-primary);
}

.last-refill-kpi-content .last-refill-details {
  display: flex;
  gap: var(--space-3);
  font-size: 1rem;
  color: var(--text-secondary);
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.last-refill-kpi-content .last-refill-liters {
  font-weight: 600;
}

.last-refill-kpi-content .last-refill-odometer {
  color: var(--text-muted);
  font-weight: 500;
}

.last-refill-kpi-content .last-refill-cost {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--color-primary);
}

.last-refill-kpi-content .last-refill-price {
  font-size: 0.875rem;
  color: var(--text-muted);
  font-weight: 500;
}

.full-tank-badge {
  padding: 2px 8px;
  background: var(--color-success);
  color: white;
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
}

/* Trip Cost Calculator Styles */
.trip-calculator-row {
  background: var(--bg-hover);
  border: none;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}

.trip-distance-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.trip-distance-group label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
  color: var(--text-primary);
}

.trip-distance-group label i {
  color: var(--color-primary);
}

.trip-distance-group .help-text {
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin: 0;
}

.trip-estimate-group {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.trip-estimate-display {
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-sm);
}

.estimate-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-1) 0;
  font-size: 0.875rem;
}

.estimate-row.highlight {
  background: rgba(0, 103, 127, 0.08);
  margin: var(--space-1) calc(-1 * var(--space-2));
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-primary);
}

.estimate-row.consumption-info {
  font-size: 0.75rem;
  color: var(--text-muted);
  border-top: 1px dashed var(--border-light);
  margin-top: var(--space-1);
  padding-top: var(--space-2);
}

.estimate-label {
  color: var(--text-secondary);
  font-weight: 500;
}

.estimate-value {
  color: var(--text-primary);
  font-weight: 600;
}

.estimate-value.cost {
  color: var(--color-primary);
  font-size: 1rem;
  font-weight: 700;
}

/* Mobile adjustments for trip calculator */
@media (max-width: 767px) {
  .trip-calculator-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .trip-estimate-display {
    margin-top: var(--space-2);
  }

  /* Mobile adjustments for inline actions row */
  .inline-actions-row {
    flex-direction: column !important;
    gap: var(--space-3) !important;
  }

  .inline-checkboxes {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: var(--space-3) !important;
    width: 100% !important;
    margin-top: var(--space-2) !important;
  }

  .inline-actions {
    width: 100% !important;
    justify-content: stretch !important;
  }

  .inline-actions .primary-btn {
    width: 100% !important;
  }
}

/* ========================================
   Mobile Bottom Navigation - Light Theme
   ======================================== */
.mobile-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--bg-mobile-nav);
  border-top: 1px solid var(--border-light);
  z-index: 100;
  padding: var(--space-2) 0 calc(var(--space-2) + env(safe-area-inset-bottom));
  box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08);
}

.mobile-bottom-nav-items {
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: var(--space-2);
}

.mobile-bottom-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  color: var(--text-mobile-nav);
  text-decoration: none;
  min-width: 60px;
  position: relative;
}

.mobile-bottom-nav-item:hover {
  background: var(--bg-hover);
  transform: translateY(-1px);
}

.mobile-bottom-nav-item.active {
  color: var(--color-primary);
}


.mobile-bottom-nav-icon {
  font-size: 1.25rem;
  transition: all var(--transition-fast);
}

.mobile-bottom-nav-item.active .mobile-bottom-nav-icon {
  color: var(--color-primary);
  transform: scale(1.1);
}

.mobile-bottom-nav-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-align: center;
  line-height: 1;
  transition: all var(--transition-fast);
}

.mobile-bottom-nav-item.active .mobile-bottom-nav-label {
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
}

/* ========================================
   More Tabs Floating Card
   ======================================== */
.more-tabs-card {
  position: fixed;
  bottom: 100px;
  right: var(--space-4);
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15), 0 4px 8px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  min-width: 200px;
  max-width: 280px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px) scale(0.95);
  transition: all var(--transition-normal);
}

.more-tabs-card.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.more-tabs-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) var(--space-4) var(--space-3);
  border-bottom: 1px solid var(--border-light);
}

.more-tabs-header h3 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin: 0;
}

.more-tabs-close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: var(--font-size-lg);
  cursor: pointer;
  padding: var(--space-1);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}

.more-tabs-close:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.more-tabs-content {
  padding: var(--space-3);
}

.more-tab-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--text-primary);
  transition: all var(--transition-fast);
  font-weight: var(--font-weight-medium);
}

.more-tab-item:hover {
  background: var(--bg-hover);
  color: var(--color-primary);
}

.more-tab-item i {
  font-size: var(--font-size-lg);
  width: 20px;
  text-align: center;
}

.more-tab-item span {
  font-size: var(--font-size-base);
}

/* ========================================
   Responsive Design
   ======================================== */

/* Large screens (1200px+) */
@media (min-width: 1200px) {
  .fuel-kpis-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Medium screens (992px - 1199px) */
@media (max-width: 1199px) {
  .kpis-row {
    flex-direction: column;
  }

  .kpi-digital-id {
    flex: 1;
    width: 100%;
  }

  .kpi-cards-group {
    flex: 1;
    width: 100%;
    grid-template-columns: repeat(3, 1fr);
  }

  .home-content-grid {
    grid-template-columns: 1fr;
  }

  .fuel-kpis-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .charts-row {
    grid-template-columns: 1fr;
  }

  .settings-page {
    grid-template-columns: 1fr;
  }
}

/* Tablet screens (768px - 991px) */
@media (max-width: 991px) {
  .sidebar {
    transform: translateX(-100%);
    width: 280px;
    transition: transform 0.3s ease;
  }

  .sidebar.sidebar-open {
    transform: translateX(0);
  }

  .mobile-overlay {
    display: none;
  }

  .mobile-overlay.active {
    display: block;
  }

  .main-area {
    margin-left: 0;
    padding-bottom: 80px; /* Space for bottom nav */
  }

  /* Hide sidebar toggle in mobile */
  .sidebar-toggle-btn {
    display: none;
  }

  .kpi-cards-group {
    grid-template-columns: repeat(3, 1fr);
  }

  .item-inputs {
    grid-template-columns: 1fr 1fr;
  }

  .item-notes {
    grid-template-columns: 1fr;
  }

  /* Ensure touch targets are large enough */
  .nav-link {
    min-height: 48px;
    padding: var(--space-3) var(--space-4);
  }

  .pagination-btn {
    min-height: 44px;
    min-width: 80px;
  }
  
  /* Show mobile bottom navigation */
  .mobile-bottom-nav {
    display: block;
  }
}

/* Small screens (576px - 767px) */
@media (max-width: 767px) {
  main {
    padding: var(--space-4);
    padding-bottom: 80px; /* Space for bottom nav */
  }

  header {
    padding: 0 var(--space-4);
  }

  header h1 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
  }

  .kpi-cards-group {
    grid-template-columns: 1fr;
  }

  /* Mobile sidebar improvements */
  .sidebar {
    width: 260px;
  }

  .nav-link {
    min-height: 52px;
    font-size: var(--font-size-base);
  }

  .nav-icon {
    font-size: 1.25rem;
  }

  /* Better touch targets for mobile */
  button,
  .pagination-btn,
  .primary-btn,
  .secondary-btn,
  .small-btn,
  .danger-btn {
    min-height: 44px;
  }

  .edit-btn,
  .delete-btn {
    min-width: 36px;
    min-height: 36px;
  }

  /* Full tank checkbox on mobile */
  .fuel-form-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
    justify-content: start;
  }

  .checkbox-wrapper {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
  }

  .full-tank-group {
    padding-top: 0;
    padding-bottom: 0;
  }

  /* Mobile checkbox label adjustments */
  .checkbox-label {
    font-size: 0.8125rem;
    gap: var(--space-1);
  }

  .checkmark {
    width: 18px;
    height: 18px;
  }

  .checkmark::after {
    font-size: 10px;
  }

  /* Mobile clear button */
  .clear-input-btn {
    width: 22px;
    height: 22px;
    font-size: 0.7rem;
  }

  .input-with-clear input {
    padding-right: 32px;
  }

  /* Ensure checkboxes stay inline */
  .full-tank-text,
  .fund-deduction-text {
    white-space: nowrap;
  }

  .kpi-card {
    min-height: auto;
  }

  .car-info-body {
    flex-direction: column;
  }

  .car-info-main {
    grid-template-columns: 1fr 1fr;
  }

  .license-expiry-box {
    width: 100%;
    max-width: none;
  }

  .fuel-kpis-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .filter-group {
    flex-direction: column;
  }

  .filter-group select {
    width: 100%;
  }

  .pagination-controls {
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-2);
  }

  .pagination-btn {
    flex: 0 0 auto;
    min-height: 42px;
    padding: var(--space-2) var(--space-3);
    font-size: 0.8125rem;
  }

  .page-info {
    flex: 1;
    text-align: center;
    font-size: 0.8125rem;
    padding: 0 var(--space-2);
  }

  .item-inputs {
    grid-template-columns: 1fr;
  }

  .actions {
    flex-direction: column;
  }

  .actions button {
    width: 100%;
  }

  .detail-grid {
    grid-template-columns: 1fr;
  }

  .popup-actions {
    flex-direction: column;
  }

  .popup-actions button {
    width: 100%;
  }

  .fuel-entry-section .form-row {
    grid-template-columns: 1fr;
  }

  .fuel-history-item {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .fuel-history-header {
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    width: 100% !important;
    padding-right: 80px !important;
    position: relative !important;
  }

  .fuel-history-header .edit-btn,
  .fuel-history-header .delete-btn {
    position: absolute !important;
    top: 0 !important;
  }

  .fuel-history-header .edit-btn {
    right: 48px !important;
  }

  .fuel-history-header .delete-btn {
    right: var(--space-2) !important;
  }

  .fuel-history-cost {
    padding: 0;
    text-align: left;
  }

  .fuel-history-details {
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-4);
  }
  
  /* Ensure mobile bottom nav is visible */
  .mobile-bottom-nav {
    display: block;
  }

  /* Fix category badges and item layout for mobile */
  .item-row {
    flex-wrap: wrap;
    gap: var(--space-1);
    align-items: flex-start;
  }

  .item-row span:first-child {
    flex: 1;
    min-width: 0;
    word-break: break-word;
  }

  .category-badge {
    margin-left: 0;
    margin-top: var(--space-1);
    flex-shrink: 0;
  }

  .session-card {
    overflow: hidden;
  }
}

/* Extra small screens (< 576px) */
@media (max-width: 575px) {
  .sidebar {
    width: 260px;
  }

  .car-info-main {
    grid-template-columns: 1fr;
  }

  .fuel-kpis-grid {
    grid-template-columns: 1fr;
  }

  .upcoming-content {
    flex-direction: column;
  }

  .upcoming-actions {
    align-self: flex-end;
  }

  .floating-btn {
    right: var(--space-4);
    bottom: var(--space-4);
    width: 48px;
    height: 48px;
    font-size: 1.25rem;
  }

  .floating-btn.secondary {
    right: calc(var(--space-4) + 56px);
  }

  .last-refill-card .refill-details {
    flex-direction: column;
    gap: var(--space-1);
  }
}

/* Very small screens (< 360px) */
@media (max-width: 359px) {
  main {
    padding: var(--space-3);
  }

  header {
    padding: 0 var(--space-3);
  }

  .panel-content {
    padding: var(--space-4);
  }

  .pagination-controls {
    gap: var(--space-2);
    flex-wrap: nowrap;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  .pagination-btn {
    padding: var(--space-2) var(--space-3);
    font-size: 0.75rem;
    min-width: 70px;
    min-height: 42px;
    flex: 1;
  }

  .page-info {
    font-size: 0.75rem;
    padding: 0 var(--space-2);
    text-align: center;
    flex: 1;
  }
}

/* Mobile pagination fix for 360x740 and similar */
@media (max-width: 380px) and (min-height: 700px) {
  .pagination-controls {
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-1);
  }

  .pagination-btn {
    flex: 0 0 auto;
    min-width: 70px;
    min-height: 42px;
    padding: var(--space-2) var(--space-3);
    font-size: 0.75rem;
  }

  .page-info {
    flex: 1;
    text-align: center;
    font-size: 0.75rem;
    padding: 0 var(--space-1);
  }
}

/* ========================================
   Utility Classes
   ======================================== */
.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;
}

.hidden {
  display: none !important;
}

/* ========================================
   FINANCE TAB STYLES
   ======================================== */

/* Finance KPIs Grid - Floosy Style */
.finance-kpis-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.finance-kpi-card {
  background: #ffffff;
  border: none;
  border-radius: 16px;
  padding: var(--space-5) var(--space-4);
  text-align: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05), 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: all var(--transition-fast);
  position: relative;
  overflow: hidden;
  min-height: 140px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.finance-kpi-card:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12), 0 4px 12px rgba(0, 0, 0, 0.08);
  transform: translateY(-4px);
  border-color: #cbd5e1;
}

/* KPI Icons - Floosy Style */
.finance-kpi-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  transition: all var(--transition-normal);
}

/* KPI specific accent colors - always visible */
.finance-kpi-card.kpi-savings::before {
  background: linear-gradient(90deg, #10b981 0%, #34d399 100%);
}

.finance-kpi-card.kpi-income::before {
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
}

.finance-kpi-card.kpi-expenses::before {
  background: linear-gradient(90deg, #ef4444 0%, #f87171 100%);
}

.finance-kpi-card.kpi-balance::before {
  background: linear-gradient(90deg, #f59e0b 0%, #fbbf24 100%);
}

.finance-kpi-card:hover::before {
  height: 6px;
}

/* KPI Icons */
.finance-kpi-card::after {
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-size: 1.5rem;
  color: #cbd5e1;
  opacity: 0.6;
  transition: all var(--transition-fast);
}

.finance-kpi-card:hover::after {
  opacity: 0.8;
  transform: scale(1.1);
}

.finance-kpi-card.kpi-savings::after {
  content: '\f4d3';
  color: #10b981;
}

.finance-kpi-card.kpi-income::after {
  content: '\f0d6';
  color: var(--color-primary);
}

.finance-kpi-card.kpi-expenses::after {
  content: '\f068';
  color: #ef4444;
}

.finance-kpi-card.kpi-balance::after {
  content: '\f24e';
  color: #f59e0b;
}

.finance-kpi-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin-bottom: var(--space-3);
  margin-top: var(--space-2);
}

.finance-kpi-main {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-black);
  color: var(--text-primary);
  margin-bottom: var(--space-2);
  letter-spacing: -0.02em;
  line-height: 1;
}

.finance-kpi-card.kpi-savings .finance-kpi-main {
  color: var(--text-primary);
}

.finance-kpi-card.kpi-income .finance-kpi-main {
  color: var(--text-primary);
}

.finance-kpi-card.kpi-expenses .finance-kpi-main {
  color: var(--text-primary);
}

.finance-kpi-card.kpi-balance .finance-kpi-main {
  color: var(--text-primary);
}

.finance-kpi-sub {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  font-weight: var(--font-weight-medium);
}

/* ========================================
   KPI Descriptions with Show More
   ======================================== */
.kpi-description-container {
  margin-top: var(--space-2);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: 1.2rem;
}

.kpi-description {
  font-size: 0.75rem;
  color: var(--text-secondary);
  line-height: 1.4;
  margin: 0;
  transition: all var(--transition-normal);
}

.kpi-description.collapsed {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kpi-description.expanded {
  display: block;
  -webkit-line-clamp: unset;
  line-clamp: unset;
}

.kpi-show-more {
  background: rgba(0, 103, 127, 0.08);
  border: 1px solid var(--border-subtle);
  color: var(--color-primary);
  font-size: 0.6875rem;
  font-weight: 600;
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  transition: all var(--transition-fast);
  align-self: center;
  border-radius: var(--radius-full);
  letter-spacing: 0.02em;
}

.kpi-show-more:hover {
  background: rgba(0, 103, 127, 0.15);
  color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(0, 103, 127, 0.15);
}

.kpi-show-more:active {
  transform: translateY(0);
  box-shadow: none;
}

/* Fuel KPI cards description adjustments */
.fuel-kpi-card .kpi-description-container {
  margin-top: var(--space-2);
}

.fuel-kpi-card .kpi-description {
  font-size: 0.6875rem;
}

.fuel-kpi-card .kpi-show-more {
  font-size: 0.625rem;
  align-self: center;
}

/* Finance KPI cards description adjustments */
.finance-kpi-card .kpi-description-container {
  margin-top: 0;
  margin-bottom: 0;
  padding-top: var(--space-1);
}

.finance-kpi-card .kpi-description {
  font-size: 0.6875rem;
  line-height: 1.3;
}

.finance-kpi-card .kpi-show-more {
  font-size: 0.625rem;
  align-self: center;
  margin-top: 0;
}

/* Home KPI cards specific adjustments */
.kpi-card .kpi-description-container {
  margin-top: var(--space-1);
  padding-top: var(--space-1);
}

/* ========================================
   Fuel Efficiency Indicator
   ======================================== */
.fuel-efficiency-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-md);
  font-size: 0.75rem;
  font-weight: 500;
}

.efficiency-badge {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
}

.efficiency-text {
  font-size: 0.6875rem;
}

/* Good efficiency - Green */
.fuel-efficiency-indicator.efficiency-good {
  background: rgba(16, 185, 129, 0.1);
  color: var(--color-success);
}

.fuel-efficiency-indicator.efficiency-good .efficiency-badge {
  background: var(--color-success);
  box-shadow: 0 0 4px var(--color-success);
}

/* Average efficiency - Yellow/Orange */
.fuel-efficiency-indicator.efficiency-average {
  background: rgba(245, 158, 11, 0.1);
  color: var(--color-warning);
}

.fuel-efficiency-indicator.efficiency-average .efficiency-badge {
  background: var(--color-warning);
  box-shadow: 0 0 4px var(--color-warning);
}

/* Poor efficiency - Red */
.fuel-efficiency-indicator.efficiency-poor {
  background: rgba(239, 68, 68, 0.1);
  color: var(--color-danger);
}

.fuel-efficiency-indicator.efficiency-poor .efficiency-badge {
  background: var(--color-danger);
  box-shadow: 0 0 4px var(--color-danger);
}

/* KPI Value Row - for side-by-side layout (value + efficiency badge) */
.kpi-value-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

.kpi-value-left {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.kpi-value-row .fuel-efficiency-indicator {
  margin-top: var(--space-1);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Fuel KPI card adjustments */
.fuel-kpi-card .fuel-efficiency-indicator {
  margin-top: var(--space-2);
}

.kpi-card .fuel-efficiency-indicator {
  margin-top: var(--space-2);
}

/* Section Header with Action */
.section-header-with-action {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
}

.section-header-with-action h2 {
  margin-bottom: 0;
}

.section-header-with-action h2::before {
  display: inline-block;
}

/* Finance Table */
.finance-table-container {
  overflow-x: auto;
  margin-bottom: var(--space-4);
}

.finance-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.finance-table thead {
  background: var(--bg-hover);
}

.finance-table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border-light);
}

.finance-table th:last-child {
  text-align: right;
}

.finance-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-light);
  color: var(--text-primary);
}

.finance-table td:last-child {
  text-align: right;
}

.finance-table tbody tr {
  transition: background var(--transition-fast);
}

.finance-table tbody tr:hover {
  background: var(--bg-hover);
}

.finance-table tbody tr:last-child td {
  border-bottom: none;
}

/* Transaction Type Badges */
.transaction-type {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.transaction-type.income {
  background: rgba(16, 185, 129, 0.1);
  color: var(--color-success);
}

.transaction-type.expense {
  background: rgba(239, 68, 68, 0.1);
  color: var(--color-danger);
}

/* Amount Colors */
.amount-income {
  color: var(--color-success);
  font-weight: 600;
  background-color: rgba(16, 185, 129, 0.1);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}

.amount-expense {
  color: var(--color-danger);
  font-weight: 600;
  background-color: rgba(239, 68, 68, 0.1);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}

/* Finance Empty State */
#financeEmptyState {
  padding: var(--space-10);
}

#financeEmptyState .empty-icon {
  color: var(--text-muted);
  font-size: 3rem;
  margin-bottom: var(--space-3);
}

/* Wallet Icon Color */
.nav-icon .fa-wallet {
  color: var(--text-secondary);
}

.nav-link.active .fa-wallet {
  color: var(--color-primary);
}

/* Add Funds Button in Header */
.section-header-with-action .primary-btn {
  margin-bottom: 0;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Responsive Finance Styles */
@media (max-width: 1199px) {
  .finance-kpis-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .finance-kpis-grid {
    grid-template-columns: 1fr;
  }

  .section-header-with-action {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .section-header-with-action .primary-btn {
    width: 100%;
    justify-content: center;
  }

  /* Convert table to card layout on mobile */
  .finance-table-container {
    overflow-x: visible;
    margin: 0;
    padding: 0;
    width: 100%;
    max-width: 100%;
  }

  .finance-table,
  .finance-table tbody,
  .finance-table tr,
  .finance-table td {
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .finance-table thead {
    display: none;
  }

  .finance-table tbody tr {
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-3);
    padding: var(--space-4);
    position: relative;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
  }

  .finance-table td {
    border: none;
    padding: var(--space-1) 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.875rem;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-wrap: break-word;
  }

  .finance-table td::before {
    content: attr(data-label);
    font-weight: 500;
    color: var(--text-muted);
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    flex-shrink: 0;
    margin-right: var(--space-3);
  }

  /* Hide action column label */
  .finance-table td.actions-cell::before {
    display: none;
  }

  .finance-table td.actions-cell {
    position: absolute;
    top: -5px;
    right: 1px;
    width: auto;
    padding: 0;
    z-index: 10;

  }

  .finance-table td.actions-cell .action-btn {
    width: 36px;
    height: 36px;
    background: var(--bg-hover);
    border-radius: var(--radius-md);
  }

  .finance-table td.actions-cell .action-btn:hover {
    background: var(--danger-50);
  }

  /* First cell (date) styling */
  .finance-table td:first-child {
    font-weight: 500;
    color: var(--text-primary);
    padding: 0 0 var(--space-3);
    border-bottom: 1px solid var(--border-light);
    margin-bottom: var(--space-3);
    font-size: 0.9375rem;
    padding-right: 80px;
    min-height: 36px;
    display: flex;
    align-items: center;
    width: 100%;
  }

  .finance-table td:first-child::before {
    content: none;
  }

  /* Amount styling - larger and bold */
  .finance-table td:nth-child(2) {
    font-size: 0.95rem;
    font-weight: 500;
    padding: var(--space-2);
    justify-content: flex-start;
    gap: var(--space-3);
    flex: 1;
    width: 300px;
    box-sizing: border-box;
  }

  .finance-table td:nth-child(2)::before {
    font-size: 0.625rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--text-muted);
  }

  /* Item column */
  .finance-table td:nth-child(3) {
    white-space: normal;
    word-wrap: break-word;
    font-size: 0.875rem;
    color: var(--text-primary);
    line-height: 1.4;
    justify-content: flex-start;
    gap: var(--space-3);
    padding: var(--space-1);
    width: 100%;
    flex: 1;
    box-sizing: border-box;
    overflow-wrap: break-word;
    word-break: break-word;
  }

  .finance-table td:nth-child(3)::before {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: var(--text-muted);
    flex-shrink: 0;
  }

  /* Type and Category columns */
  .finance-table td:nth-child(4),
  .finance-table td:nth-child(5) {
    padding: var(--space-1);
    justify-content: flex-start;
    gap: var(--space-3);
    width: 100%;
    flex: 1;
    box-sizing: border-box;
  }

  .finance-table td:nth-child(4)::before,
  .finance-table td:nth-child(5)::before {
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: var(--text-muted);
    flex-shrink: 0;
  }
}

@media (max-width: 575px) {

  /* On very small screens, only show Date, Amount, Item, Actions */
  .finance-table th:nth-child(4),
  .finance-table td:nth-child(4) {
    display: none;
  }

  /* Ensure Amount column is visible */
  .finance-table th:nth-child(2),
  .finance-table td:nth-child(2) {
    display: table-cell;
  }

  /* Make Item column wrap text */
  .finance-table td:nth-child(3) {
    white-space: normal;
    word-wrap: break-word;
  }
}

/* Transaction Details Popup Styles */
.transaction-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-light);
  gap: var(--space-4);
}

.transaction-detail-row:last-child {
  border-bottom: none;
}

.transaction-detail-row label {
  font-weight: 600;
  color: var(--text-secondary);
  font-size: 0.875rem;
  flex-shrink: 0;
  min-width: 100px;
}

.transaction-detail-row span {
  color: var(--text-primary);
  text-align: right;
  word-break: break-word;
}

.transaction-detail-row .transaction-type {
  margin-left: auto;
}

/* Finance Table Action Buttons */
.finance-table .actions-cell {
  text-align: center;
  white-space: nowrap;
  min-width: 50px;
}

.finance-table .action-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-1);
  margin: 0 2px;
  border-radius: var(--radius-sm);
  transition: background-color 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  min-height: 32px;
  margin-left: 10px;
}

.finance-table .action-btn:hover {
  background-color: var(--bg-tertiary);
}

.finance-table .action-btn.edit-btn {
  color: var(--color-primary);
}

.finance-table .action-btn.edit-btn:hover {
  background-color: var(--bg-active);
  color: var(--color-primary-dark);
}

.finance-table .action-btn.delete-btn {
  color: var(--color-danger);
}

.finance-table .action-btn.delete-btn:hover {
  background-color: var(--danger-50);
}

/* Fund Deduction Checkbox - Uses shared .checkbox-label styles */
.fund-deduction-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}

.fund-deduction-text {
  white-space: nowrap;
  font-weight: 500;
  color: var(--text-primary);
}

/* Checkbox group styling */
.checkbox-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin: 0;
}

.checkbox-group .help-text {
  margin-left: calc(var(--space-2) + 20px);
  margin-top: 0;
  font-size: 0.75rem;
}

/* ========================================
   Floating Card Component (matches site design)
   ======================================== */
.floating-card {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.2s ease-out;
  font-family: var(--font-sans);
}

.floating-card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(8px);
  pointer-events: auto;
}

.floating-card-container {
  position: relative;
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  max-width: 90%;
  width: 400px;
  max-height: 90vh;
  overflow: hidden;
  animation: slideUp 0.25s ease-out;
  pointer-events: auto;
}

.floating-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  background: var(--color-primary);
  color: var(--text-on-primary);
}

.floating-card-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.floating-card-close {
  background: none;
  border: none;
  color: var(--text-on-primary);
  cursor: pointer;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.floating-card-close:hover {
  background-color: rgba(255, 255, 255, 0.15);
  color: var(--text-on-primary);
}

.floating-card-body {
  padding: var(--space-5);
}

.floating-card-message {
  margin: 0 0 var(--space-4) 0;
  color: var(--text-primary);
  line-height: 1.5;
  font-size: var(--font-size-base);
  font-family: var(--font-sans);
}

.floating-card-input {
  width: 100%;
  padding: var(--space-3);
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-family: var(--font-sans);
  color: var(--text-primary);
  transition: var(--transition-fast);
  margin-top: var(--space-4);
  background: var(--bg-hover);
}

.floating-card-input:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 103, 127, 0.15);
}

.floating-card-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  padding: var(--space-4) var(--space-5);
  background: var(--bg-page);
}

.floating-card-btn {
  padding: var(--space-3) var(--space-6);
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  font-family: var(--font-sans);
  cursor: pointer;
  transition: var(--transition-fast);
  min-width: 80px;
  pointer-events: auto;
}

.floating-card-btn-cancel {
  background: var(--bg-hover);
  color: var(--text-primary);
  border: none;
}

.floating-card-btn-cancel:hover {
  background: var(--bg-active);
  color: var(--text-primary);
}

.floating-card-btn-confirm {
  background: var(--color-primary);
  color: var(--text-on-primary);
}

.floating-card-btn-confirm:hover {
  background: var(--color-primary-dark);
}

.floating-card-btn:active {
  transform: translateY(0);
}

/* Animations */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Responsive design */
@media (max-width: 480px) {
  .floating-card-container {
    width: 95%;
    margin: var(--space-4);
  }
  
  .floating-card-header,
  .floating-card-body,
  .floating-card-actions {
    padding: var(--space-4);
  }
  
  .floating-card-actions {
    flex-direction: column;
  }
  
  .floating-card-btn {
    width: 100%;
  }
}