/* Load local font files */
/* Grouped by 'Congenial' font family */
@font-face {
  font-family: "Congenial";
  src: url("/fonts/Congenial_Light.otf") format("otf");
  font-weight: 200;
  font-style: normal;
}
@font-face {
  font-family: "Congenial";
  src: url("/fonts/Congenial_Regular.otf") format("otf");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Congenial";
  src: url("/fonts/Congenial_Medium.otf") format("otf");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "Congenial";
  src: url("/fonts/Congenial_Bold.otf") format("woff");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Congenial_Black";
  src: url("/fonts/Congenial_Black.otf") format("otf");
  font-weight: 900;
  font-style: normal;
}
/* Define reusable variables */
:root {
  /* Colors */
  --agahf-green: #3CB64C;
  --agahf-dark-green: #037103;
  --agahf-text-green: #001B00;
  --agahf-gold: #DE9803;
  --agahf-green-gradient: linear-gradient(to bottom, #3c9a4cf2 26%, #037103);
  --primary-color: #69b1ff;
  --primary-color-hover: #0072ec;
  --primary-color-light: #69b1ff;
  --primary-color-bg: #eaf6ff;
  --primary-color-bg: #fff;
  --primary-color-subtle: #deeffd;
  --secondary-color: #0072ec;
  --dark-color: #203764;
  --dark-color-light: #304266;
  --accent-color: #f76c1c;
  --accent-color-hover: #ed7d31;
  --accent-color-hover-2: #9b501e;
  --danger-color: #721c24;
  --error-color: #ff4d4d;
  --error-bg-color: #f8d7da;
  --error-border-color: #f5c6cb;
  --success-color: #28a745;
  --success-bg-color: #d4edda;
  --success-border-color: #c3e6cb;
  --text-color: var(--dark-color);
  --text-light-color: var(--primary-color-bg);
  --background-color: var(--primary-color-bg);
  --button-background-color: var(--accent-color);
  --button-background-color-hover: var(--accent-color-hover);
  --white-color: #fff;
  /* Spacing */
  --padding-small: 12px;
  --padding-medium: 24px;
  --padding-large: 32px;
  --padding-xlarge: 48px;
  --padding-y-small: 16px 0;
  --padding-y-medium: 32px 0;
  --padding-y-large: 56px 0;
  --padding-hor-small: 0 16px;
  --padding-hor-medium: 0 24px;
  --padding-hor-large: 0 32px;
  --padding-hor-xlarge: 0 56px;
  --margin-y-small: 16px 0;
  --margin-y-normal: 24px 0;
  --margin-y-medium: 32px 0;
  --margin-y-large: 56px 0;
  --margin-hor-small: 0 16px;
  --margin-hor-medium: 0 24px;
  --margin-hor-large: 0 32px;
  --margin-hor-xl: 0 56px;
  /* Border radius */
  --border-radius: 4px;
  --border-radius-large: 8px;
  /* Font family and sizes */
  --font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-heading: "Congenial", var(--font-family);
  /* Responsive Typography Variables */
  --font-size-small: clamp(12px, 1vw + 10px, 14px);
  /* Scales between 12px and 14px */
  --font-size-regular: clamp(14px, 1vw + 12px, 16px);
  /* Scales between 14px and 16px */
  --font-size-medium: clamp(18px, 2vw + 14px, 24px);
  /* Scales between 18px and 24px */
  --font-size-large: clamp(24px, 3vw + 16px, 32px);
  /* Scales between 24px and 32px */
  --font-size-xlarge: clamp(32px, 4vw + 18px, 48px);
  /* Scales between 32px and 48px */
  --font-size-xxlarge: clamp(32px, 5vw + 20px, 56px);
  /* Scales between 40px and 56px */
  /* Box shadow */
  --box-shadow-light: 0 4px 8px rgba(0, 0, 0, 0.1);
  --box-shadow-medium: 0 4px 10px rgba(0, 0, 0, 0.1);
  /* Transitions */
  --transition-bg: background-color 0.3s ease-in-out;
  --transition-normal: all 0.3s ease-in-out;
  --transition-fast: all 0.2s ease-in-out;
  /* Buttons */
  --button-padding: var(--padding-small) var(--padding-medium);
  --button-font-size: inherit;
  --button-font-family: var(--font-heading);
  --button-border-radius: var(--border-radius);
  --button-box-shadow: var(--box-shadow-light);
  --button-transition: var(--transition-normal);
  /* Layout */
  --2-cols: repeat(2, 1fr);
  --3-cols: repeat(3, 1fr);
}

/* Modern CSS Reset */
/* Box sizing: more intuitive box-sizing model */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Set up the base font size and family */
html {
  font-size: 100%;
  /* Use the browser's default font size */
  scroll-behavior: smooth;
  /* Enable smooth scrolling */
}

body {
  font-family: var(--font-family);
  background-color: var(--background-color);
  color: var(--text-color);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Media & form resets */
/* Ensure images, videos, and other media fit their containers */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

/* Remove default list styles */
ul,
ol {
  list-style: none;
}

/* Remove default link styling */
a {
  text-decoration: none;
  color: inherit;
  transition: var(--transition-normal);
}

/* Set a consistent border style */
hr {
  border: none;
  height: 1px;
  background-color: #eaeaea;
}

/* Form reset - Remove default form styling */
input,
button,
textarea,
select {
  font: inherit;
  border: none;
  background: none;
  width: 100%;
}

/* Buttons*/
button,
input[type=button] {
  width: unset;
}

/* Radio buttons */
input[type=radio],
input[type=checkbox] {
  margin-right: 6px;
  width: unset;
}

/* Make buttons and inputs clickable */
button,
select,
option {
  cursor: pointer;
  background-color: transparent;
}

/* Responsive motion */
/* Remove animations from media queries (for people who prefer reduced motion) */
@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}
/* General layout */
.container {
  width: 100%;
  max-width: 1200px;
  padding: var(--padding-hor-large);
  margin-inline: auto;
}

/* Text Alignment */
.text-center {
  text-align: center;
}

p.text-center {
  max-width: unset;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.static {
  position: static;
}

.content-centered {
  display: grid;
  place-items: center;
}

.bold {
  font-weight: bold;
}

/* Grid Containers */
.grid-1 {
  display: grid;
  gap: 20px;
}

.grid-2 {
  display: grid;
  grid-template-columns: var(--2-cols);
  gap: 20px;
}

.grid-3 {
  display: grid;
  grid-template-columns: var(--3-cols);
  gap: 20px;
}

.grid-2n1 {
  display: grid;
  grid-template-columns: 2, 1fr 1fr;
  gap: 10px;
}

.grid-container {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.grid-container .card {
  margin-bottom: unset;
}

.grid-1-3 {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 1rem;
}

.grid-4 {
  display: grid;
  grid-template-columns: auto-fit, minmax(75px, 1fr);
  grid-auto-columns: 100px;
}

.grid-sidebar-collapsed {
  grid-template-columns: 60px 1fr;
  /* Hide the sidebar and let the container fill the space */
  transition: grid-template-columns 0.3s ease;
  /* Smooth transition for collapse/expand */
}
.grid-sidebar-collapsed .sidebar-head {
  display: none;
}

.grid-sidebar-expanded {
  grid-template-columns: 300px 1fr;
  /* Sidebar takes 300px, and the rest goes to the container */
  transition: grid-template-columns 0.3s ease;
  /* Smooth transition for collapse/expand */
}
.grid-sidebar-expanded .sidebar-switch .switch i {
  transform: rotate(180deg);
}

.icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(20px, 1fr));
  gap: 10px;
  justify-content: center;
}

.accent {
  color: var(--accent-color);
}

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

.danger {
  background-color: var(--error-color);
  color: var(--white-color);
}

.good {
  background-color: var(--primary-color-hover);
  color: var(--white-color);
}

.dark {
  background-color: var(--dark-color);
  color: var(--white-color);
}

title {
  font-size: 1.5rem;
  background-color: var(--success-bg-color);
}

/* General grid container for displaying uploaded images/files */
.file-grid {
  width: 110px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(50px, 1fr)); /* Auto-adjusts columns */
  gap: 10px;
  justify-content: center;
}

/* Standardized image size and styling */
.file-thumbnail {
  width: 50px;
  height: 50px;
  -o-object-fit: cover;
     object-fit: cover;
  border: 1px solid black;
}

/* Admin Dashboard Main Layout */
.dashboard {
  padding: 2rem 2rem 2rem 0;
}
.dashboard h3 {
  margin: 2rem 0;
  color: var(--accent-color);
}
.dashboard .container {
  padding: 0;
}

.dashboard section {
  margin-bottom: 2rem;
}

/* Card Styling */
.card-container {
  background-color: #f9f9f9;
  padding: 1.5rem 1.5rem 2.5rem;
  border-radius: 8px;
}

.card {
  background-color: #ffffff;
  padding: 1.5rem;
  border-radius: 8px;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

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

/* Quick Links Specific Styles */
.main-content {
  background-color: white;
  padding: 20px;
  border-radius: 5px;
  box-shadow: var(--box-shadow-medium);
}

.card {
  background-color: #f9f9f9;
  padding: 15px;
  margin-bottom: 20px;
  border-radius: 5px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
}
.card ul,
.card li,
.card p {
  max-width: unset;
  margin-inline: unset;
}

.card-inner-vflex {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
}
.card-inner-vflex .card-head h4 {
  position: relative;
}
.card-inner-vflex .card-head h4::after {
  content: "";
  position: absolute;
  display: block;
  height: 2px;
  width: 40%;
  background-color: var(--accent-color);
  translate: 50% 50%;
  right: 50%;
  margin-top: 4px;
}

.card h3 {
  margin-top: 0;
  margin-bottom: 1.2rem;
}

.card h4 {
  margin-top: 0;
  line-height: 1.2;
  margin-bottom: 1rem;
}

.stats .card:last-child,
.operations .card:last-child {
  margin-right: 0;
}

.statistics .db-mgt {
  grid-column: span 2;
  text-align: center;
}

.survey-prompt a {
  color: var(--accent-color);
  font-weight: 700;
}

a.card {
  text-align: center;
  font-weight: 700;
  border: 1px solid transparent;
  transition: var(--transition-normal);
}
a.card i {
  line-height: 0;
}
a.card:hover {
  border: 1px solid var(--text-color);
}

/* Header */
header {
  position: sticky;
  /* Ensures relative positioning for absolute child elements */
  top: 0;
  z-index: 1000;
  background-color: #f5f5f5;
  padding: 10px 20px;
  border-bottom: 1px solid #ddd;
}

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

.logo img {
  height: 40px;
  width: auto;
}

nav.toggler {
  position: relative;
  /* Parent container for absolute positioning */
}

nav.toggler ul {
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 15px;
}

nav.toggler ul li {
  /* Ensures child elements are positioned relative to this item */
  padding: 10px 15px;
  cursor: pointer;
  font-size: 16px;
}

nav.toggler ul li.no-pad {
  padding: 0;
}

.nav-item {
  transition: color 0.3s;
}

.nav-item:hover {
  color: #007bff;
}

.nav-item .nav-links {
  /* Initially hide sub-menu */
  display: block;
  position: absolute;
  top: 100%;
  /* Positions submenu below the nav item */
  left: 0;
  width: 100%;
  /* Span the width of the grandparent container */
  background-color: #fff;
  border: 1px solid #ddd;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  /* Transition setup */
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  /* Start slightly above */
  transition: opacity 0.3s ease-out, transform 0.3s ease-out, visibility 0.3s ease-out;
}

.nav-item:hover .nav-links {
  border-radius: 5px;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  /* Reset to normal position */
}

.nav-links li {
  padding: 10px;
  border-bottom: 1px solid #f0f0f0;
}

.nav-links li:last-child {
  border-bottom: none;
}

.nav-item .right-zero {
  position: absolute;
  left: auto;
  right: 0;
  text-align: right;
}

.nav-links li a {
  /* Style links within the submenu */
  color: var(--text-color);
  display: block;
  transition: var(--transition-normal);
}

.nav-links li a:hover {
  color: #007bff;
  font-weight: 600;
  padding-left: 0.3rem;
}

.inline-link {
  transition: var(--transition-normal);
}

.hamburger-menu {
  display: none;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
}
.hamburger-menu span {
  width: 25px;
  height: 3px;
  background-color: var(--white-color);
  border-radius: 2px;
}

.sidebar {
  position: sticky;
  top: 4rem;
  overflow: hidden;
  max-width: 300px;
  color: var(--dark-color);
  background-image: url(../images/12151159_4880206.jpg);
  background-position: center center;
  background-size: cover;
  padding: 15px;
  border-radius: 5px;
  box-shadow: var(--box-shadow-medium);
  height: 100vh;
  transition: all 0.3s ease;
}
.sidebar .sidebar-switch {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--dark-color-light);
}
.sidebar .switch i {
  border: 1px solid var(--dark-color-light);
  border: var(--border-radius-large);
  font-size: 1.5rem;
  padding: 0.5rem;
  cursor: pointer;
}
.sidebar a {
  color: var(--dark-color);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 5px;
  padding: 5px;
  border: 1px solid transparent;
  border-radius: 5px;
  position: relative;
  width: 100%;
  overflow: hidden;
}
.sidebar a i {
  min-width: 20px;
  text-align: center;
}
.sidebar a span {
  display: inline-block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  transition: opacity 0.3s ease;
}
.sidebar a:hover {
  border: 1px solid var(--dark-color-light);
  padding-left: 1em;
  font-weight: 700;
}
.sidebar.collapsed {
  max-width: 70px;
  overflow: hidden;
}
.sidebar.collapsed a span {
  display: none;
}
.sidebar.collapsed a::after {
  content: attr(data-label);
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0, 0, 0, 0.75);
  color: #fff;
  padding: 5px 10px;
  border-radius: 5px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  z-index: 10;
  margin-left: 10px;
  font-size: 0.85rem;
}
.sidebar.collapsed a:hover::after {
  opacity: 1;
}
.sidebar.collapsed.link-text {
  display: none;
}

.menu-ctrls {
  display: none;
}
.menu-ctrls i {
  font-size: 1.5rem;
  padding: 0.5rem;
  cursor: pointer;
}

.logo {
  width: 48px;
}

.logo-large {
  width: 30%;
  margin-inline: auto;
}

/* Text styling */
.head {
  font-family: var(--font-heading);
  font-size: var(--font-size-medium);
}

p.subhead {
  margin-bottom: 1.5rem;
}

p {
  max-width: 60ch;
}

h1,
h2,
h3,
h4 {
  font-family: var(--font-heading);
  text-align: center;
}

h1 {
  font-size: var(--font-size-xxlarge);
  line-height: 1;
  margin: 1.5rem 0;
}

h2 {
  font-size: var(--font-size-xlarge);
  line-height: 1.2;
  margin-bottom: 24px;
}

h3 {
  font-size: var(--font-size-large);
}

h4 {
  font-size: var(--font-size-medium);
}

/* Section */
.h-flex {
  display: flex;
  justify-content: space-between;
  align-items: self-end;
  gap: 1rem;
  flex-wrap: wrap;
}
.h-flex .btn-grp {
  margin: 0;
  flex-wrap: wrap;
}

.flex-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

@media (max-width: 500px) {
  .h-flex {
    flex-direction: column;
    align-items: center;
  }
  .weekly-logs {
    overflow: scroll;
  }
}
.v-flex {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: var(--margin-y-normal);
}

.btn-grp {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  margin: var(--margin-y-normal);
}
.btn-grp .btn-outline {
  width: unset;
}

.qlinks {
  padding: var(--padding-y-medium);
  justify-content: left;
}

.btn {
  display: inline-block;
  background-color: var(--accent-color);
  color: var(--white-color);
  font-weight: bold;
  letter-spacing: 1px;
  padding: var(--padding-small) var(--padding-medium);
  text-decoration: none;
  text-align: center;
  border-radius: var(--border-radius);
  border: 1px solid transparent;
  transition: var(--transition-normal);
}

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

.btn-secondary {
  background-color: var(--text-color);
  color: var(--white-color);
}
.btn-secondary:hover {
  background-color: var(--text-color);
  opacity: 0.9;
}

.btn-outline {
  background-color: transparent;
  color: var(--primary-color);
  border: 1px solid var(--primary-color);
  width: 100%;
}

.btn-outline:hover {
  background-color: unset;
  opacity: 0.7;
}

.btn-dark {
  background-color: var(--text-color);
  color: var(--white-color);
}
.btn-dark:hover {
  background-color: var(--white-color);
  color: var(--text-color);
  border: 1px solid var(--text-color);
}

.btn-dark-outline {
  background-color: transparent;
  color: var(--text-color);
  border: 1px solid var(--text-color);
}
.btn-dark-outline:hover {
  background-color: var(--dark-color);
  color: var(--white-color);
}

.wide-table {
  width: 100%;
  overflow: scroll;
}

.admin-users table {
  width: 100%;
  box-shadow: var(--box-shadow-light);
}

.admin-user-action-container {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: center;
}

.reg-action {
  padding: 2px 6px;
  color: var(--white-color);
  border-radius: 4px;
}

.reg-action:hover {
  opacity: 0.8;
}

.btn-approve {
  background-color: var(--success-color);
}

.btn-block {
  background-color: var(--error-color);
}

.btn-unblock {
  background-color: var(--success-color);
}

/* Footer */
footer {
  background-color: #f8f9fa;
  font-size: 14px;
  border-top: 1px solid #ddd;
  text-align: center;
  padding: var(--padding-small);
  font-size: var(--font-size-small);
  position: relative;
}

.dev {
  font-weight: 700;
  letter-spacing: 1px;
  border-radius: 4px;
  text-decoration: underline;
  border: 1px solid transparent;
  transition: var(--transition-normal);
}
.dev:hover {
  text-decoration: none;
}

/* Privacy Policy and Terms-of-Use Styling */
.policy h1 {
  font-size: var(--font-size-xlarge);
}
.policy h2 {
  font-size: var(--font-size-small);
  text-align: left;
}
.policy ul {
  margin-bottom: 1.5rem;
}

/* Back to Top Button */
.back-to-top {
  position: absolute;
  bottom: 2.5rem; /* Adjust as per footer padding */
  right: 1.5rem; /* Space from the right */
  width: 40px;
  height: 40px;
  background-color: var(--primary-color-hover);
  color: var(--white-color);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  transition: background-color 0.3s ease, transform 0.2s ease;
}
.back-to-top:hover {
  background-color: #0056b3;
  transform: translateY(-3px); /* Slight upward movement on hover */
}
.back-to-top i {
  font-size: 18px;
}

/* Page-specific styling */
/* Testing Colors*/
/*PASSWORD RESET*/
.reset-request form {
  text-align: left;
}
.reset-request form button {
  margin-top: unset;
  width: 100%;
}

.table-page-container {
  margin: 0 1.2rem 1.2rem;
  overflow: hidden;
}
.table-page-container .btn-grp {
  justify-content: left;
}

.table-page-head h1 {
  text-align: center;
}

.dashboard-table {
  overflow: scroll;
}

.full-height main.user-feedback {
  place-items: unset;
}

/*MESSAGES PAGE*/
.messages {
  margin: var(--margin-y-large);
}
.messages h2,
.messages h3 {
  color: var(--accent-color);
  font-size: var(--font-size-large);
  margin-bottom: 24px;
}
.messages h1 {
  margin-bottom: 32px;
}

.message-item {
  background-color: #f9f9f9;
  padding: var(--padding-medium);
  margin-bottom: 20px;
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow-medium);
}

/*USER PROFILE PAGE*/
.user-profile-icon {
  padding: 0.5em !important;
}

.user-profile-icon img {
  display: inline-block;
  width: 32px;
  border-radius: 50%;
}

.profile-page main {
  margin: var(--margin-y-medium);
}

.profile-container {
  text-align: left;
  max-width: 800px;
}
.profile-container section {
  padding: var(--padding-medium);
  border: 1px solid #deeffd;
  transition: var(--transition-fast);
}
.profile-container section h4 {
  margin: 32px 0 10px 0;
}
.profile-container .profile-pic {
  padding: 0;
  box-shadow: none;
  display: flex;
  align-items: center;
  position: relative;
}
.profile-container .profile-pic img {
  margin-inline: auto;
}
.profile-container .profile-edit {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  padding: 0.5em;
  background-color: var(--text-color);
  color: var(--white-color);
  border-radius: 5px;
  box-shadow: var(--box-shadow-medium);
}
.profile-container .profile-edit:hover {
  transform: translate(0, -5px);
}
.profile-container .personal-container {
  display: grid;
  gap: 20px;
}
.profile-container .profile-title {
  font-size: var(--font-size-large);
  margin-bottom: unset;
}
.profile-container .theme-preference form {
  margin-top: 24px;
}
.profile-container .theme-preference form .btn-grp {
  justify-content: unset;
}
.profile-container .btn-grp {
  margin: unset;
}

.profile-container section:hover {
  box-shadow: var(--box-shadow-medium);
}

.card-outline {
  padding: var(--padding-medium);
  border: 1px solid #deeffd;
  transition: var(--transition-fast);
}
.card-outline h4 {
  margin: 32px 0 10px 0;
}
.card-outline:hover {
  box-shadow: var(--box-shadow-light);
}

#login-main {
  display: flex;
}

.login-main {
  width: 100%;
}
.login-main .login-container {
  display: flex;
  justify-content: space-between;
  height: 100vh;
  width: 100vw;
}
.login-main .intro-container {
  padding: var(--padding-large);
  background-color: var(--text-color);
  background-image: url(/images/Underground-truck-and-truck-operators-2048x1366.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  background-blend-mode: overlay;
  color: var(--white-color);
  width: 70%;
  text-align: left;
  display: flex;
  flex-direction: column;
}
.login-main .intro-content {
  margin-inline: auto;
  padding: var(--padding-hor-large);
}
.login-main .intro-content h1 {
  text-align: left;
  max-width: 600px;
}
.login-main .intro-content ul, .login-main .intro-content li, .login-main .intro-content p {
  font-size: 1.5rem;
}
.login-main .intro-content p {
  margin-bottom: 24px;
}
.login-main .intro-content li {
  margin-left: 32px;
  position: relative;
}
.login-main .login-form {
  width: 30%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.login-main .form-container {
  box-shadow: none;
  padding: var(--padding-large);
}
.login-main .v-flex {
  margin: 0;
}

.icon {
  display: flex;
}

.icon-small {
  width: 32px;
  margin-right: 1rem;
}

.full-height {
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.full-height header {
  margin-bottom: 0;
}
.full-height main {
  flex-grow: 1;
  display: grid;
  place-items: center;
}
.full-height .inner-flex {
  text-align: center;
}
.full-height .inner-flex form {
  text-align: left;
}

#soon {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

#soon main {
  flex-grow: 1;
}
#soon main .container {
  min-height: 700px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: space-between;
}
#soon main .coming-soon-container .logo-large {
  margin-bottom: 32px;
}
#soon main .btn-grp {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin: 32px 0;
}
#soon main .btn-grp a {
  width: unset;
  margin: unset;
}

/* Index page styling */
.home-main .intro {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
.home-main p {
  font-size: 20px;
  margin-bottom: 20px;
}
.home-main ul {
  font-size: 20px;
  margin-inline: auto;
}

/* Form container */
.form-container {
  max-width: 600px;
  margin: 0 auto;
  padding: var(--padding-xlarge);
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow-light);
  overflow: hidden;
}
.form-container h2 {
  font-size: var(--font-size-medium);
}

/* Form headings */
.triage-page h1,
.triage-page h3 {
  color: var(--accent-color);
  text-align: center;
  margin-bottom: var(--heading-margin, 20px);
}
.triage-page h3 {
  margin-top: 30px;
}
.triage-page .form-container {
  max-width: 800px;
}

.incident-page .form-container {
  max-width: 800px;
}

.book-summary-container {
  margin: 0 1.2rem 1.2rem;
}

.book-summary h4 {
  color: var(--accent-color);
  margin-bottom: 0.5rem;
}
.book-summary .post-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.book-summary .post-summary .card {
  border: 1px solid var(--text-color);
  padding: 5px 0.5rem;
  margin-bottom: 0;
}
.book-summary .post-summary a.card {
  border-bottom: 2px solid transparent;
  font-weight: 400;
  background-color: var(--text-color);
  color: var(--white-color);
}
.book-summary .post-summary a.card:hover {
  border-bottom: 2px solid var(--accent-color);
}
.book-summary .post-summary a.card[data-expiry-date=nearing-expiry] {
  background-color: var(--error-color);
  border: none;
  font-weight: 700;
}

/* Form input groups */
/* Form elements */
.input-grp {
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.input-grp label[for=disposition] {
  display: block;
  margin-bottom: 10px;
}

.input-grp-hor {
  flex-direction: row;
  justify-content: space-between;
}
.input-grp-hor .btn {
  margin-top: unset;
  width: -moz-max-content;
  width: max-content;
}

.input-grp label {
  font-family: var(--font-heading);
  font-weight: bold;
}

.input-grp input,
.input-grp select,
.input-grp textarea {
  padding: var(--input-padding, 10px);
  border: 1px solid var(--input-border-color, #ccc);
  border-radius: var(--input-border-radius, 4px);
  font-size: var(--input-font-size, 16px);
  font-family: var(--body-font-family, "Arial", sans-serif);
}

.input-grp select {
  height: 100%;
}

textarea {
  resize: vertical;
}

/* TEWS */
form > div {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.message-container {
  max-width: 765px;
  margin-inline: auto;
  text-align: center;
  padding: var(--padding-large);
}
.message-container p {
  font-size: 1.2rem;
  margin-inline: auto;
}
.message-container .post-summary {
  justify-content: center;
}

/* Admin Page Styles */
#admin .container {
  max-width: 100%;
}

.dashboard-page h1 {
  text-align: center;
  margin-bottom: 32px;
}

#admin .admin-container {
  margin: 0 auto;
  padding: var(--padding-medium);
  background-color: var(--white-color);
  border-radius: var(--border-radius-large);
  box-shadow: var(--box-shadow-medium);
}

#admin h1 {
  font-size: var(--font-size-large);
}

/* Filter Section */
#admin .filter-section h3,
.records-section h3,
.export-section h3 {
  color: var(--text-color);
}

#admin .filter-section form {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin-inline: auto;
  margin-bottom: 20px;
}

#admin .filter-section label {
  margin-right: 10px;
}

#admin .filter-section input,
.filter-section select,
.filter-section button {
  margin-right: 10px;
  padding: 8px;
  border-radius: 4px;
  border: 1px solid #ddd;
}

/* Records Table */
table {
  border-collapse: collapse;
  box-shadow: var(--box-shadow-medium);
}

tr:nth-child(odd) {
  background-color: var(--primary-color-subtle);
}

thead th {
  background-color: var(--accent-color);
  font-weight: 700;
  color: var(--white-color);
  position: sticky;
  top: 0;
}

th.details {
  min-width: 300px;
}

th,
td {
  padding: var(--padding-small);
  border: 1px solid rgba(211, 211, 211, 0.5137254902);
  text-align: left;
}

/* Highlight problematic equipment rows */
.equipment-alert {
  background-color: #ffe6e6 !important; /* Light red background */
  color: #b30000; /* Dark red text */
  font-weight: bold;
}

.table-subhead {
  font-weight: 700;
}

.table-totals {
  background-color: var(--dark-color) !important;
  color: var(--white-color);
  font-weight: 700;
}

/* Export Section */
#admin .export-section h3 {
  text-align: left;
}

#admin .export-section form {
  display: flex;
  align-items: center;
}

#admin .export-section label {
  margin-right: 10px;
}

#admin .export-section button {
  margin-left: 10px;
  height: 100%;
}

/* FLASH ALERTS */
.alert-parent {
  position: relative;
  margin-inline: auto;
}

.alert {
  z-index: 100;
  padding: 8px 16px;
  border-radius: 5px;
  width: 100%;
  max-width: 500px;
  text-align: center;
  box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
  position: absolute;
  top: 0;
  right: 0;
  opacity: 1;
  transition: opacity 0.5s ease-in-out;
}

/* Show only if content is present */
.alert:empty {
  display: none;
}

.alert:not(:empty) {
  display: block;
}

.user-table-container .alert {
  top: -40px;
}

.alert-danger {
  background-color: var(--error-bg-color);
  color: var(--danger-color);
  border: 1px solid var(--error-border-color);
}

.alert-success {
  background-color: var(--success-bg-color);
  color: var(--success-color);
  border: 1px solid var(--success-border-color);
}

/* Overlay for session alert */
.session-overlay {
  display: block;
  /* Displayed dynamically */
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.5);
  /* Semi-transparent black */
  z-index: 999;
  /* Behind the .session-alert */
}

.session-alert {
  background-color: var(--error-bg-color);
  color: var(--text-color);
  border: 1px solid var(--error-border-color);
  box-shadow: var(--box-shadow-medium);
  position: fixed;
  inset: 50%;
  translate: -50% -50%;
  padding: 1.5rem;
  width: 30%;
  height: -moz-fit-content;
  height: fit-content;
  border-radius: 5px;
  z-index: 1000;
}
.session-alert .warn {
  color: var(--danger-color);
  font-weight: bold;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}
.session-alert .countdown {
  background-color: var(--white-color);
  font-weight: 700;
  padding: 0.3rem 0.5rem;
}
.session-alert .session-btn {
  margin-top: 1.5rem;
  display: flex;
  gap: 10px;
}

/* Common Bordered Element */
.bordered-element {
  border: 1px solid var(--border-color, #ddd);
  /* Set a default, but use a variable */
  border-radius: var(--border-radius-small, 4px);
  /* Consistent rounded corners */
  padding: var(--padding-small, 8px);
  /* Consistent padding */
}

/* Striped Table */
.striped-table {
  border-collapse: collapse;
  margin-top: 56px;
  box-shadow: var(--box-shadow-medium);
}

.striped-table tr:nth-child(odd) {
  background-color: var(--primary-color-subtle);
}

.striped-table th,
.striped-table td {
  text-align: left;
}

.striped-table thead th {
  background-color: var(--accent-color);
  font-weight: 700;
  color: var(--white-color);
}

/* Flash message animation (fade-out) */
.alert.fade-out {
  opacity: 1;
  transition: opacity 1s ease-in-out;
  animation: fadeOut 5s forwards;
}

@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.close-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  background: none;
  border: none;
  font-size: 16px;
  cursor: pointer;
  color: #555;
}

.close-btn:hover {
  color: #000;
}

/*Floating Feedback Button*/
.feedback-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: none;
  /* Initially hidden */
  z-index: 1000;
}

.feedback-float button {
  background-color: var(--accent-color);
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 10px 20px;
  font-size: 16px;
  cursor: pointer;
  box-shadow: var(--box-shadow-medium);
  transition: var(--transition-normal);
}

.feedback-float button:hover {
  background-color: var(--text-color);
}

/* INVENTORY MGT */
.filter-with-breadcrumbs {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 1.2rem 1.2rem;
}
.filter-with-breadcrumbs .flex-wrap {
  gap: 10px;
}

.filter-container .filter-grp {
  flex-direction: row;
}
.filter-container .filter-grp select {
  height: auto;
}
.filter-container .filter-grp option {
  color: var(--text-color);
}
.filter-container .btn {
  background-color: var(--primary-color-subtle);
  color: var(--text-color);
}
.filter-container .btn:hover {
  background-color: var(--text-color);
  color: var(--white-color);
}
.filter-container .input-grp {
  margin-bottom: 0;
}
.filter-container input,
.filter-container select {
  border: 1px solid var(--primary-color-subtle);
  padding-inline: 10px;
}

.wide-table .filter-with-breadcrumbs {
  margin: 0 0 20px 0;
}

/* STATISTICS PAGE STYLING */
.stats-page .monthly-stats .filter-with-breadcrumbs {
  margin: 0;
}
.stats-page .monthly-stats h3 {
  margin-bottom: 10px;
}
.stats-page .monthly-stats .table-page-container {
  margin: 0;
}

.btn-lone {
  margin-top: 1.5rem;
}

.fixed-footer-body {
  position: relative;
}
.fixed-footer-body footer {
  position: fixed;
  clear: both;
  bottom: 0;
  box-shadow: 0 -4px 8px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  width: 100%;
}

.inventory-table-container {
  padding: var(--padding-large);
  flex-grow: 1;
}
.inventory-table-container h1,
.inventory-table-container h2 {
  text-align: left;
}

.breadcrumb {
  padding: 10px;
  background-color: #f8f9fa;
  border: 1px solid #ddd;
  border-radius: 5px;
}

.breadcrumb span {
  margin-right: 8px;
}

.breadcrumb .badge {
  font-size: 14px;
  padding: 5px 10px;
  border-radius: 12px;
}

.breadcrumb .badge-primary {
  background-color: var(--text-color);
  color: var(--white-color);
}

.breadcrumb .badge-info {
  background-color: var(--primary-color-subtle);
  color: var(--text-color);
}

.no-items {
  margin: 20px 0;
  text-align: center;
  font-size: 18px;
  color: var(--error-color);
  font-weight: bold;
}

/* Items Register Page */
.items-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

.item-card {
  overflow: visible;
  transition: box-shadow 0.2s ease;
  display: flex;
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 10px;
  cursor: pointer;
  width: 100%;
  max-width: 300px;
  transition: transform 0.2s ease;
  position: relative;
}
.item-card img {
  margin-right: 10px;
  border: 1px solid #f4f4f4;
  border-radius: 8px;
}
.item-card .mod-reg-item {
  position: absolute;
  right: 10px;
}
.item-card .mod-reg-item .mod-reg-link {
  padding: 0.65rem;
}

.item-card:hover {
  transform: scale(1.05);
}

.item-card img {
  width: 80px;
  height: 80px;
  -o-object-fit: cover;
     object-fit: cover;
}

.item-card .item-text h4 {
  margin: 0;
  font-size: 1.2em;
}

.item-card:hover {
  box-shadow: var(--box-shadow-light);
}

.item-card-content {
  display: flex;
  padding: 10px;
  width: 100%;
}

.item-icon {
  width: 80px;
  height: 80px;
  margin-right: 16px;
}

.item-text h3 {
  margin: 0;
  font-size: 1.2rem;
}

.item-text p {
  margin: 5px 0 0;
  color: #666;
  font-size: 0.9rem;
}

.item-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}

.items-register {
  position: relative;
}

.modal {
  display: none;
}

#item-modal,
#edit-modal,
#report-modal {
  inset: 50%;
  translate: -50% -50%;
  width: 40%;
  border: none;
  border-radius: 10px;
  padding: 20px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  /* margin-inline: auto; */
  position: absolute;
  color: var(--text-color);
}
#item-modal .h-flex,
#edit-modal .h-flex,
#report-modal .h-flex {
  justify-content: left;
  margin-top: 1rem;
}
#item-modal .h-flex button,
#edit-modal .h-flex button,
#report-modal .h-flex button {
  padding: 0.2rem 0.5rem;
}
#item-modal .modal-content,
#edit-modal .modal-content,
#report-modal .modal-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#item-modal .modal-content .item-details,
#item-modal .modal-content .report-details,
#edit-modal .modal-content .item-details,
#edit-modal .modal-content .report-details,
#report-modal .modal-content .item-details,
#report-modal .modal-content .report-details {
  flex: 1;
  padding: 10px;
}
#item-modal .modal-close,
#edit-modal .modal-close,
#report-modal .modal-close {
  background: transparent;
  font-size: 1em;
  cursor: pointer;
  position: absolute;
  top: 20px;
  right: 20px;
}

.items-register main {
  position: relative;
}

.modify-register {
  position: sticky;
  bottom: 2rem;
  right: 2rem;
  margin-bottom: 1rem;
  z-index: 1000;
  place-self: end;
}

.mod-reg-items {
  display: none;
}

.mod-reg-item {
  display: inline-block;
  z-index: 100;
}
.mod-reg-item:hover > .mod-reg-items {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: absolute;
  top: -13rem;
}

.top-gap {
  padding-top: 1rem;
}

.mod-reg-link {
  display: inline-block;
  padding: 1rem;
  border-radius: var(--border-radius-large);
  box-shadow: var(--box-shadow-light);
}
.mod-reg-link:hover {
  background-color: var(--primary-color-subtle);
}

.shown {
  display: block;
}

/* Hide menu by default */
.hidden {
  display: none;
}

.card-edit-items.hidden {
  display: none;
}

.card-edit-items {
  position: relative;
  top: 5px;
  right: 208%;
  z-index: 100;
  display: block;
}
.card-edit-items .card-edit-items-inner {
  width: 100%;
  display: flex;
  gap: 5px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1000;
}
.card-edit-items .card-edit-items-inner .mod-reg-link {
  padding: 0.8rem;
  border: 1px solid var(--primary-color-subtle);
  box-shadow: none;
  background-color: var(--white-color);
}
.card-edit-items .card-edit-items-inner .mod-reg-link:hover {
  color: var(--accent-color);
}

/* Style the menu */
@media (max-width: 668px) {
  .item-card {
    max-width: 100%;
  }
  #item-modal,
  #edit-modal {
    width: 100%;
  }
  .modal-content {
    width: 80%;
  }
  .modal-content button {
    width: unset;
  }
  .modal-content .h-flex {
    flex-direction: row;
  }
}
/* Responsive layout */
@media (max-width: 950px) {
  .session-alert {
    width: 40%;
    max-width: 400px;
  }
  .nav-container {
    flex-direction: column;
  }
  .menu-ctrls {
    display: block;
    position: absolute;
    top: 1rem;
    left: 1rem;
  }
  .grid-1-3 {
    grid-template-columns: 1fr;
  }
  .sidebar {
    position: fixed;
    top: 60px;
    left: -100%;
    width: 80%;
    height: 100vh;
    background-color: var(--white-color); /* fallback bg */
    z-index: 1000;
    transition: left 0.3s ease;
    opacity: 0.97;
  }
  .sidebar.mobile-open {
    left: 0;
  }
  /* Inventory page */
  .main-content {
    width: 100vw;
  }
  /*Filters*/
}
/* Responsive layout */
@media (max-width: 768px) {
  .container {
    padding: var(--padding-hor-medium);
  }
  .grid-3 {
    grid-template-columns: 1fr 1fr;
  }
  .grid-1-3 {
    grid-template-columns: 1fr;
  }
  .intro-content p, .intro-content ul {
    display: none;
  }
  .login-main .intro-content li {
    margin-left: 0;
  }
  .login-container {
    flex-direction: column;
  }
  .login-container .intro-content ul, .login-container .intro-content li, .login-container .intro-content p {
    font-size: 12px;
  }
  .login-container .login-form, .login-container .intro-container,
  .login-container .form-container {
    width: 100%;
  }
  .btn {
    font-size: 14px;
  }
  .form-container {
    padding: var(--padding-medium);
  }
  .inventory-table-container {
    flex-grow: 1;
  }
  .inventory-table-container h1,
  .inventory-table-container h2 {
    text-align: center;
  }
  .book-summary .table-page-container {
    margin: 0;
  }
  .book-summary .post-summary {
    gap: 0.5rem;
  }
  .book-summary h5 {
    font-size: 12px;
  }
  .breadcrumb, .filter-container {
    width: 100%;
  }
}
@media (max-width: 500px) {
  .session-alert {
    width: 60%;
  }
  .container {
    padding: var(--padding-small);
  }
  .home-main .qlinks {
    padding: unset;
    margin-top: 2em;
  }
  .grid-container {
    grid-template-columns: 1fr;
  }
  .grid-container .db-mgt {
    grid-column: unset;
  }
  /* Show sub-menu when .nav-item touched on mobile*/
  .nav-item:hover > .nav-links {
    margin-top: 0.6rem;
  }
  form > div {
    grid-template-columns: 1fr;
  }
  .grid-2 {
    grid-template-columns: unset;
  }
  .grid-2 .input-grp:not(:last-child) {
    margin-bottom: 0;
  }
  .grid-3 {
    grid-template-columns: unset;
  }
  /* Incident Form*/
  .incident-page .container {
    padding: 0;
  }
  /* Buttons*/
  button,
  input[type=button],
  .btn {
    width: 100%;
  }
  button.modal-close {
    width: unset;
  }
  .dashboard .card-container {
    padding: 1.5rem;
  }
  .dashboard h3 {
    margin: 0 0 1rem 0;
    line-height: 1.2;
  }
  .session-alert {
    width: 80%;
  }
  /* Index page styling */
  .home-main p {
    font-size: 1rem;
    margin: 1rem;
    text-align: center;
  }
  .home-main ul {
    font-size: 1rem;
    margin-inline: auto;
  }
  .home-main p,
  .home-main ul {
    width: 300px;
  }
  .dashboard {
    padding: 0;
  }
  .card {
    text-align: center;
  }
  /* INVENTORY MGT */
  .options:nth-child(odd) {
    background-color: var(--primary-color-bg);
  }
  .landing-page-body {
    padding: 1rem;
  }
}
@media (max-width: 650px) {
  .nav-container {
    flex-direction: row;
  }
  .menu-ctrls {
    position: unset;
  }
  .sidebar-switch .switch {
    display: none;
  }
  /* Style the hamburger menu */
  .hamburger-menu {
    display: flex;
    flex-direction: column;
    gap: 4px;
    cursor: pointer;
  }
  .hamburger-menu span {
    background-color: var(--text-color);
    height: 4px;
    width: 30px;
    border-radius: 2px;
  }
  /* Show toggled menu */
  .show-menu {
    display: block !important;
  }
  /* Toggler for the navigation menu */
  nav.toggler {
    position: absolute;
    top: 60px;
    right: 0;
    width: 70%;
    height: 70vh;
    background-color: #f5f5f5;
    z-index: 1000;
    display: none;
    flex-direction: column;
    padding: 20px;
    box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2);
  }
  nav.toggler ul {
    flex-direction: column;
    gap: 10px;
  }
  nav.toggler ul li {
    width: 100%;
    padding: 10px;
    border-bottom: 1px solid #ddd;
    text-align: right;
    position: relative;
    /* Parent is relative for absolute positioning of submenu */
  }
  /* Submenu styles */
  .nav-links {
    display: none;
    /* Initially hidden */
    position: absolute;
    top: 50%;
    /* Position right below the parent nav-item */
    left: -30px;
    /* Shift slightly to the right */
    flex-direction: column;
    background-color: #ffffff;
    padding: 1rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    border: 1px solid #ddd;
    border-radius: 4px;
    z-index: 1100;
    /* Ensure it's above the main menu */
  }
  .nav-links li {
    padding: 5px 0;
  }
  .nav-links li a {
    color: #333;
    font-size: 14px;
    text-decoration: none;
    transition: color 0.3s ease;
  }
  .nav-links li a:hover {
    color: #007bff;
  }
  /* Show submenus on hover or toggle */
  .nav-item:hover .nav-links,
  .nav-item .nav-links.show-sublinks {
    display: flex;
    /* Show sub-links */
  }
}
/* NURSING-HUB */
/* Landing Page */
.landing-page-body {
  margin-top: 2rem;
  padding: 3rem 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
.landing-page-body .onboard a {
  padding: 0.8rem 1rem;
  border-radius: var(--border-radius-large);
}
.landing-page-body .onboard a:hover {
  opacity: 0.8;
}

.post-selection-page-body {
  height: 100vh;
  display: grid;
  place-content: center;
  background-image: url(/images/AGA-191206-1875-e1659496079789-2048x1208.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}
.post-selection-page-body .post-selection {
  margin: 1em;
  background-color: rgba(255, 255, 255, 0.8705882353);
  border-radius: var(--border-radius-large);
}
.post-selection-page-body .post-selection select {
  background-color: rgba(255, 255, 255, 0.8235294118);
  padding: 1em;
}

.landing-page {
  text-align: center;
  max-width: 800px;
  margin-inline: auto;
  padding: 2rem;
}
.landing-page label {
  margin-bottom: 1rem;
}

.hub-prompt {
  max-width: 800px;
  margin-inline: auto;
  margin-bottom: 3rem;
  font-size: var(--font-size-large);
  color: var(--text-color);
}

.onboard-new {
  display: none;
}

.shown {
  display: block;
}

/* Options container */
.options {
  display: flex;
  justify-content: center;
  gap: 2em;
  flex-wrap: wrap;
  max-width: 600px;
  margin-inline: auto;
}

/* Card styling for options */
.option-card {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 14em;
  height: 14em;
  padding: var(--padding-large);
  border-radius: var(--border-radius-large);
  border: 1px solid #deeffd;
  box-shadow: var(--box-shadow-light);
  text-align: center;
  color: var(--text-color);
  text-decoration: none;
  transition: var(--transition-normal);
  opacity: 0;
  /* Start hidden */
  position: relative;
  /* Hover effects */
  /* Icon styling */
  /* Option text styling */
}
.option-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--box-shadow-medium);
  background-color: var(--text-color);
  color: var(--white-color);
}
.option-card:hover .icon {
  color: var(--white-color);
}
.option-card .icon,
.option-card .icon i > svg {
  font-size: 5rem;
  /* Make the icon large */
  display: block;
  margin-bottom: var(--margin-y-small);
  margin-inline: auto;
  color: var(--primary-color);
  transition: var(--transition-normal);
}
.option-card .option-text {
  font-size: var(--font-size-medium);
  font-weight: 500;
}

/* Initial placement outside the viewport */
.iAid,
.iSoup,
.iManage,
.iEmerge {
  opacity: 0;
  /* Start fully transparent */
}

.iAid {
  transform: translateY(100vw);
  /* Positioned off-screen to the left */
  background-color: var(--primary-color-bg, orange);
  /* Fallback color */
}

.iSoup {
  transform: translateY(100vw);
  /* Positioned off-screen to the right */
  background-color: var(--primary-color-subtle, lightcoral);
  /* Fallback color */
}

.iEmerge {
  transform: translateY(100vw);
  /* Positioned off-screen to the left */
  background-color: var(--primary-color-subtle, lightcoral);
  /* Fallback color */
}

.iManage {
  transform: translateY(100vw);
  /* Positioned off-screen to the right */
  background-color: var(--primary-color-bg, orange);
  /* Fallback color */
}

/* Slide-in animation for iAid from the left */
@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateY(100vw);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Slide-in animation for iSoup from the right */
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateY(100vw);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Apply animations with slower duration */
.iAid.animate {
  animation: slideInLeft 1.5s ease-out forwards;
}

.iSoup.animate {
  animation: slideInRight 1.5s ease-out forwards;
}

.iEmerge.animate {
  animation: slideInLeft 1.5s ease-out forwards;
}

.iManage.animate {
  animation: slideInRight 1.5s ease-out forwards;
}

@media (max-width: 600px) {
  .options {
    flex-direction: column;
  }
  .landing-page {
    padding: 0;
  }
  .option-card {
    width: 80%;
    /* Full-width on smaller screens */
    margin-bottom: var(--margin-y-small);
    margin-inline: auto;
  }
}
/* iSOUP*/
.isoup .isoup-table-hidden {
  display: none;
}
.isoup .card {
  margin-bottom: 0;
}
.isoup .h-flex {
  justify-content: unset;
  margin: 2rem 0;
}
.isoup .filter-container {
  margin-top: 2rem;
}
.isoup .pagination a {
  margin: 0 5px;
  text-decoration: none;
}
.isoup .pagination a.active {
  font-weight: bold;
  color: var(--accent-color);
}

#isoup header,
#isoup footer,
#imanage header,
#imanage footer {
  background-color: var(--text-color);
  color: var(--white-color);
}
#isoup .intro,
#imanage .intro {
  margin-top: 2rem;
}

/* iManage*/
.switch-btn {
  padding: 10px 20px;
  margin: 10px;
  border: none;
  border-radius: 5px;
  background-color: #009879;
  color: white;
  cursor: pointer;
  font-size: 14px;
  transition: background-color 0.3s;
}

.switch-btn:hover {
  background-color: #007861;
}

/* iEmerge */
.pending div {
  height: 300px;
  overflow-y: scroll;
}
.pending div table {
  width: 100%;
}
.pending div table a {
  padding: 3px 5px;
  background-color: var(--primary-color-hover);
  color: var(--white-color);
  border-radius: 3px;
}

.iemerge-inventory i {
  color: var(--success-color);
}
.iemerge-inventory i.fa-exclamation-circle {
  color: var(--error-color);
}

/* Styling for the main accordion container */
.accordion {
  background-color: #f5f5f5;
  /* Light background color */
  padding: 1.5rem;
  border-radius: 0.5rem;
  box-shadow: var(--box-shadow-light);
  margin-bottom: 20px;
}

/* Styling for the heading of the accordion */
.accordion h2 {
  font-size: 24px;
}

/* Styling for the buttons in the accordion */
.accordion-btn-grp {
  display: flex;
  flex-direction: column;
  /* Stack the buttons vertically */
  gap: 10px;
  /* Add some spacing between buttons */
}

/* General button styling */
.incident-trigger {
  background-color: var(--text-color);
  /* Primary blue color */
  color: var(--white-color);
  padding: 12px 20px;
  border: 1px solid var(--text-color);
  text-align: center;
  border-radius: 5px;
  /* Rounded corners */
  cursor: pointer;
  transition: var(--transition-normal);
  width: 100%;
  /* Make the button span full width */
}

/* Hover and active states for buttons */
.incident-trigger:hover,
.incident-trigger:active,
.accordion-active {
  background-color: var(--white-color);
  color: var(--text-color);
  border: 1px solid var(--text-color);
}

/* Incident form container */
.incident {
  margin: 2rem 0;
}
.incident .form-container {
  background-color: var(--white-color);
}

/* Responsive Design for Larger Screens (optional) */
@media (min-width: 768px) {
  .accordion-btn-grp {
    flex-direction: row;
    /* Arrange buttons horizontally on larger screens */
    justify-content: center;
    /* Distribute buttons evenly */
  }
  .incident-trigger {
    width: auto;
    /* Revert to auto width on larger screens */
  }
}
/* SETTINGS PAGE STYLING */
.settings-container {
  display: grid;
  gap: 20px;
  margin-top: 96px;
}
.settings-container i {
  color: var(--accent-color);
}

/* Database Management */
.db-management .input-grp {
  display: grid;
}
.db-management .import-export {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: baseline;
  gap: 1em;
}
.db-management button {
  text-align: center;
}/*# sourceMappingURL=mineaid-styles.css.map */