:root {
  --navy-950: #061328;
  --navy-900: #0a1c38;
  --navy-850: #10264b;
  --navy-800: #15315d;
  --navy-700: #25497f;
  --blue-500: #2c73da;
  --blue-300: #8ab8ff;
  --teal-300: #64d8d3;
  --green-500: #21a558;
  --green-300: #7ae3a7;
  --amber-400: #f3b949;
  --red-400: #f26d6d;
  --bg: #eef3fb;
  --panel: #ffffff;
  --panel-soft: #f7faff;
  --ink: #102240;
  --muted: #6c7a93;
  --line: #d9e2f1;
  --shadow: 0 16px 42px rgba(11, 28, 62, 0.12);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(88, 141, 255, 0.12), transparent 22%),
    linear-gradient(180deg, #f7faff 0%, #edf3fb 100%);
  color: var(--ink);
  font-family: "Barlow", sans-serif;
}

.login-body {
  background:
    radial-gradient(circle at top left, rgba(56, 116, 226, 0.22), transparent 22%),
    radial-gradient(circle at bottom right, rgba(42, 207, 192, 0.12), transparent 20%),
    linear-gradient(180deg, #061224 0%, #09172c 100%);
  color: white;
  min-height: 100vh;
}

.portal-login {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1.28fr) minmax(480px, 0.72fr);
  background: #051122;
}

.portal-login__visual,
.portal-login__panel {
  position: relative;
  min-width: 0;
}

.portal-login__visual {
  overflow: hidden;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background-color: #051122;
  background-position: left center;
  background-repeat: no-repeat;
  background-size: cover;
}

.portal-login__hero-image,
.portal-login__visual-overlay {
  position: absolute;
  inset: 0;
}

.portal-login__hero-image {
  background: #051122;
  transform: none;
  z-index: 0;
}

.portal-login__hero-image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
  display: block;
  filter: saturate(1.02) brightness(0.9);
  transform: scale(1.42);
  transform-origin: left center;
}

.portal-login__visual-overlay {
  background:
    linear-gradient(90deg, rgba(5, 17, 34, 0.14), rgba(5, 17, 34, 0.34)),
    radial-gradient(circle at 50% 78%, rgba(255, 187, 102, 0.14), transparent 14%);
  z-index: 1;
}

.portal-login__visual-overlay,
.portal-login__telemetry,
.portal-login__headline,
.portal-login__status-row {
  display: none;
}

.portal-login__telemetry,
.portal-login__headline,
.portal-login__status-row {
  position: relative;
  z-index: 2;
}

.portal-login__telemetry {
  display: grid;
  gap: 8px;
  color: rgba(236, 242, 255, 0.82);
  font-size: 0.95rem;
  letter-spacing: 0.05em;
}

.portal-login__telemetry div {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.portal-login__telemetry i {
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: #29c8ff;
  box-shadow: 0 0 10px rgba(41, 200, 255, 0.48);
}

.portal-login__headline {
  max-width: 520px;
  margin-top: auto;
  margin-bottom: 28px;
}

.portal-login__headline h1 {
  margin: 0;
  font-family: "Barlow", sans-serif;
  font-size: clamp(2.7rem, 4vw, 4.3rem);
  line-height: 1.08;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-weight: 700;
}

.portal-login__headline em {
  color: #1eb8ff;
  font-style: normal;
}

.portal-login__headline-rule {
  width: 60px;
  height: 3px;
  border-radius: 999px;
  margin: 18px 0 16px;
  background: linear-gradient(90deg, #12d2ff, #2a74f2);
}

.portal-login__headline p {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.6;
  color: rgba(232, 239, 255, 0.86);
  max-width: 460px;
}

.portal-login__status-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  padding: 16px 12px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(8, 24, 52, 0.84), rgba(8, 19, 40, 0.84));
  border: 1px solid rgba(111, 157, 230, 0.24);
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.24);
  backdrop-filter: blur(8px);
}

.portal-login__status-row article {
  padding: 10px 18px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.portal-login__status-row article:last-child {
  border-right: 0;
}

.portal-login__status-row strong,
.portal-login__status-row span {
  display: block;
}

.portal-login__status-row strong {
  font-size: 1.02rem;
  margin-bottom: 8px;
  color: #f1f6ff;
}

.portal-login__status-row span {
  font-size: 1.02rem;
  color: #2de38a;
}

.portal-login__panel {
  padding: 22px 24px;
  display: grid;
  align-items: stretch;
  background: linear-gradient(180deg, #061328 0%, #07152c 100%);
}

.portal-login__card {
  width: min(100%, 670px);
  margin: 0 auto;
  padding: 44px 40px 34px;
  border-radius: 18px;
  border: 1px solid rgba(130, 161, 219, 0.38);
  background: linear-gradient(180deg, rgba(6, 22, 48, 0.94), rgba(4, 16, 36, 0.94));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 22px 44px rgba(0, 0, 0, 0.24);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.portal-login__brand {
  display: grid;
  justify-items: center;
  gap: 10px;
  margin-bottom: 28px;
  text-align: center;
}

.portal-login__logo {
  width: 208px;
  max-width: 100%;
  height: auto;
  display: block;
}

.portal-login__logo--full {
  width: min(100%, 360px);
  filter: drop-shadow(0 18px 28px rgba(0, 0, 0, 0.28));
}

.portal-login__logo svg {
  width: 100%;
  height: auto;
  display: block;
}

.portal-login__intro {
  margin-bottom: 26px;
}

.portal-login__intro h2 {
  margin: 0 0 8px;
  color: #ffffff;
  font-size: clamp(2rem, 2.4vw, 2.6rem);
}

.portal-login__intro p {
  margin: 0;
  color: rgba(222, 230, 245, 0.86);
  font-size: 1.03rem;
}

.portal-login__form {
  display: grid;
  gap: 16px;
}

.portal-login__field {
  display: grid;
  gap: 10px;
}

.portal-login__field > span {
  color: #f0f5ff;
  font-size: 0.96rem;
  font-weight: 600;
}

.portal-login__input-shell {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) 24px;
  align-items: center;
  gap: 14px;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 10px;
  border: 1px solid rgba(110, 142, 194, 0.34);
  background: rgba(7, 20, 43, 0.62);
}

.portal-login__input-shell input {
  width: 100%;
  border: 0;
  outline: none;
  background: transparent;
  color: #f8fbff;
  font: inherit;
  font-size: 1.02rem;
  padding: 15px 0;
}

.portal-login__input-shell input::placeholder {
  color: rgba(192, 206, 229, 0.7);
}

.portal-login__input-icon {
  display: block;
  width: 18px;
  height: 18px;
  position: relative;
  opacity: 0.88;
}

.portal-login__password-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.portal-login__password-toggle:focus-visible {
  outline: 2px solid rgba(17, 184, 255, 0.9);
  outline-offset: 2px;
  border-radius: 6px;
}

.portal-login__input-icon.user::before,
.portal-login__input-icon.user::after,
.portal-login__input-icon.lock::before,
.portal-login__input-icon.lock::after,
.portal-login__input-icon.eye::before,
.portal-login__input-icon.eye::after {
  content: "";
  position: absolute;
}

.portal-login__input-icon.user::before {
  left: 4px;
  top: 1px;
  width: 8px;
  height: 8px;
  border: 2px solid rgba(222, 230, 245, 0.84);
  border-radius: 50%;
}

.portal-login__input-icon.user::after {
  left: 1px;
  bottom: 1px;
  width: 14px;
  height: 8px;
  border: 2px solid rgba(222, 230, 245, 0.84);
  border-top: 0;
  border-radius: 0 0 10px 10px;
}

.portal-login__input-icon.lock::before {
  left: 3px;
  top: 1px;
  width: 10px;
  height: 8px;
  border: 2px solid rgba(222, 230, 245, 0.84);
  border-bottom: 0;
  border-radius: 9px 9px 0 0;
}

.portal-login__input-icon.lock::after {
  left: 2px;
  bottom: 1px;
  width: 12px;
  height: 9px;
  border: 2px solid rgba(222, 230, 245, 0.84);
  border-radius: 3px;
}

.portal-login__input-icon.eye::before {
  inset: 4px 1px;
  border: 2px solid rgba(222, 230, 245, 0.84);
  border-radius: 12px / 8px;
}

.portal-login__input-icon.eye::after {
  left: 6px;
  top: 6px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(222, 230, 245, 0.84);
}

.portal-login__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.portal-login__remember {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(232, 238, 255, 0.9);
}

.portal-login__remember input {
  width: 18px;
  height: 18px;
  accent-color: #19b4ff;
  cursor: pointer;
}

.portal-login__link,
.portal-login__request a {
  color: #12b8ff;
  font-weight: 600;
}

.portal-login__submit {
  width: 100%;
  min-height: 54px;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(180deg, #1cbcff, #1e7eff);
  color: #ffffff;
  font: inherit;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 16px 30px rgba(24, 122, 255, 0.24);
}

.portal-login__submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(24, 122, 255, 0.3);
}

.portal-login__request {
  margin-top: 22px;
  text-align: center;
  color: rgba(232, 238, 255, 0.82);
  font-size: 1rem;
}

.portal-login--register {
  grid-template-columns: minmax(0, 1.18fr) minmax(560px, 0.82fr);
}

.portal-login__card--register {
  width: min(100%, 760px);
  padding-bottom: 30px;
}

.portal-login__form--register {
  gap: 14px;
}

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

.portal-login__input-shell--simple {
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
}

.portal-login__input-shell--simple input,
.portal-login__input-shell--select select {
  padding: 15px 0;
}

.portal-login__input-shell--select select {
  width: 100%;
  border: 0;
  outline: none;
  background: transparent;
  color: #f8fbff;
  font: inherit;
  font-size: 1.02rem;
  appearance: none;
}

.portal-login__input-shell--select {
  position: relative;
}

.portal-login__input-shell--select::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 50%;
  width: 10px;
  height: 10px;
  margin-top: -8px;
  border-right: 2px solid rgba(222, 230, 245, 0.84);
  border-bottom: 2px solid rgba(222, 230, 245, 0.84);
  transform: rotate(45deg);
  pointer-events: none;
}

.portal-login__help {
  margin: 4px 0 0;
  color: rgba(198, 208, 226, 0.84);
  font-size: 0.94rem;
  line-height: 1.55;
}

.portal-login__note {
  margin-top: 18px;
}

.portal-login__secure {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(131, 161, 212, 0.18);
  text-align: center;
}

.portal-login__secure strong,
.portal-login__secure span {
  display: block;
}

.portal-login__secure strong {
  color: rgba(233, 239, 255, 0.82);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.82rem;
  margin-bottom: 10px;
}

.portal-login__secure span {
  color: rgba(194, 206, 227, 0.82);
}

.portal-login__debug {
  margin-top: 18px;
  text-align: left;
}

.portal-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 22px 34px;
  background: linear-gradient(180deg, #041126 0%, #08152d 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 30px rgba(2, 10, 23, 0.3);
}

.portal-topbar-brand,
.portal-topbar-links {
  display: flex;
  align-items: center;
  gap: 18px;
}

.portal-topbar-links {
  color: rgba(235, 242, 255, 0.88);
  flex-wrap: wrap;
}

.portal-topbar-links a,
.status-live {
  padding: 0 14px;
  border-left: 1px solid rgba(255,255,255,0.16);
  font-size: 0.98rem;
}

.portal-topbar-links a {
  opacity: 0.88;
}

.portal-topbar-links a:hover {
  opacity: 1;
}

.portal-topbar-links > :first-child {
  border-left: 0;
  padding-left: 0;
}

.status-live {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.status-live i {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #24c260;
  box-shadow: 0 0 0 6px rgba(36, 194, 96, 0.12);
}

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

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 284px minmax(0, 1fr);
}

.sidebar {
  background:
    linear-gradient(180deg, rgba(34, 77, 133, 0.18), transparent 22%),
    linear-gradient(180deg, var(--navy-950), #07101f 100%);
  color: #f3f7ff;
  padding: 28px 22px 24px;
  display: flex;
  flex-direction: column;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
}

.sidebar-brand::before {
  content: none;
}

.brand-mark {
  width: 64px;
  min-width: 64px;
  height: 64px;
  border-radius: 20px;
  display: grid;
  align-content: center;
  gap: 8px;
  padding: 13px 12px;
  background: linear-gradient(180deg, rgba(42, 87, 153, 0.92), rgba(17, 43, 88, 0.98));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.brand-mark span {
  display: block;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eff5ff, #8ac7ff);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.brand-mark span:nth-child(1) {
  width: 100%;
}

.brand-mark span:nth-child(2) {
  width: 72%;
}

.brand-mark span:nth-child(3) {
  width: 88%;
}

.sidebar-brand > div:last-child {
  display: block;
}

.brand-title {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.brand-title.long {
  max-width: 146px;
  font-size: 1.3rem;
  line-height: 1.02;
}

.brand-title.compact {
  font-size: 1.35rem;
  color: #172d58;
}

.brand-subtitle {
  color: rgba(231, 240, 255, 0.72);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
}

.brand-subtitle.dark {
  color: #6f7d95;
}

.brand-mark.dark span {
  background: linear-gradient(180deg, #193567, #0d1f44);
}

.side-nav {
  display: grid;
  gap: 6px;
}

.side-nav-label {
  margin: 14px 10px 4px;
  color: rgba(221, 232, 251, 0.68);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.nav-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-radius: 14px;
  color: rgba(241, 246, 255, 0.85);
  font-size: 1.02rem;
  transition: background 0.2s ease, transform 0.2s ease;
}

.nav-item:hover,
.nav-item.active {
  background: linear-gradient(180deg, rgba(61, 101, 163, 0.42), rgba(28, 56, 102, 0.74));
  color: #fff;
  transform: translateX(2px);
}

.nav-item em {
  font-style: normal;
  display: inline-grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  background: var(--blue-500);
  font-size: 0.82rem;
  font-weight: 700;
}

.sidebar-footer {
  margin-top: auto;
  padding-top: 28px;
}

.support-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #d7e6ff;
}

.support-button {
  background: transparent;
  cursor: pointer;
  font: inherit;
}

.login-stage {
  min-height: 100vh;
}

.login-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(470px, 620px);
  gap: 0;
}

.login-hero,
.login-panel {
  min-width: 0;
}

.login-hero {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.airline-style {
  min-height: calc(100vh - 93px);
}

.airline-hero {
  overflow: hidden;
  padding: 92px 64px 42px;
  background:
    radial-gradient(circle at 68% 82%, rgba(255, 198, 125, 0.18), transparent 12%),
    radial-gradient(circle at 10% 92%, rgba(247, 190, 120, 0.12), transparent 16%),
    linear-gradient(180deg, rgba(6, 18, 40, 0.42), rgba(6, 18, 40, 0.84)),
    linear-gradient(180deg, #061224 0%, #0b1a34 58%, #07101d 100%);
}

.hero-world {
  position: absolute;
  inset: 84px 16% 32% 22%;
  background:
    radial-gradient(circle at 22% 44%, rgba(110, 168, 255, 0.9), rgba(110, 168, 255, 0) 12px),
    radial-gradient(circle at 41% 36%, rgba(110, 168, 255, 0.7), rgba(110, 168, 255, 0) 10px),
    radial-gradient(circle at 59% 42%, rgba(110, 168, 255, 0.85), rgba(110, 168, 255, 0) 12px),
    radial-gradient(circle at 76% 34%, rgba(110, 168, 255, 0.8), rgba(110, 168, 255, 0) 10px),
    linear-gradient(transparent 0 0);
  opacity: 0.72;
  pointer-events: none;
}

.hero-world::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 42%, rgba(67, 94, 148, 0.34) 0 13%, transparent 14%),
    radial-gradient(ellipse at 35% 30%, rgba(67, 94, 148, 0.28) 0 14%, transparent 15%),
    radial-gradient(ellipse at 53% 43%, rgba(67, 94, 148, 0.3) 0 13%, transparent 14%),
    radial-gradient(ellipse at 68% 33%, rgba(67, 94, 148, 0.28) 0 12%, transparent 13%),
    radial-gradient(ellipse at 81% 41%, rgba(67, 94, 148, 0.24) 0 10%, transparent 11%);
  filter: blur(2px);
}

.hero-routes {
  position: absolute;
  inset: 90px 12% 34% 26%;
  pointer-events: none;
}

.hero-routes::before,
.hero-routes::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, transparent 0 36%, rgba(86, 133, 230, 0.35) 36.5%, transparent 37%) no-repeat,
    linear-gradient(160deg, transparent 0 42%, rgba(86, 133, 230, 0.25) 42.5%, transparent 43%) no-repeat,
    linear-gradient(195deg, transparent 0 47%, rgba(86, 133, 230, 0.24) 47.5%, transparent 48%) no-repeat,
    linear-gradient(25deg, transparent 0 53%, rgba(86, 133, 230, 0.22) 53.5%, transparent 54%) no-repeat;
  opacity: 0.9;
}

.route-dot {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f4fbff;
  box-shadow: 0 0 18px rgba(126, 179, 255, 0.9);
}

.dot-a { top: 32%; left: 24%; }
.dot-b { top: 24%; left: 44%; }
.dot-c { top: 39%; left: 61%; }
.dot-d { top: 28%; left: 82%; }

.airline-copy {
  position: relative;
  z-index: 2;
  max-width: 540px;
  margin-top: 42px;
}

.airline-copy h1 {
  font-size: 4.55rem;
  line-height: 0.93;
  max-width: 620px;
}

.hero-rule {
  width: 48px;
  height: 4px;
  margin: 28px 0 24px;
  border-radius: 999px;
  background: linear-gradient(90deg, #25d37f, #1fb862);
}

.hero-safety-card {
  position: relative;
  z-index: 2;
  margin-top: 34px;
  width: 320px;
  padding: 24px 24px 22px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(14, 34, 68, 0.82), rgba(11, 25, 50, 0.7));
  border: 1px solid rgba(154, 191, 255, 0.18);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.26);
  backdrop-filter: blur(10px);
}

.hero-safety-card strong {
  display: block;
  margin-bottom: 10px;
  font-size: 1.1rem;
}

.hero-safety-card span {
  color: rgba(235, 242, 255, 0.72);
  line-height: 1.55;
}

.hero-aircraft {
  position: absolute;
  left: 18%;
  right: 8%;
  bottom: 62px;
  height: 290px;
  z-index: 1;
  opacity: 0.96;
}

.hero-plane-body {
  position: absolute;
  left: 12%;
  right: 3%;
  bottom: 34px;
  height: 126px;
  border-radius: 94px 126px 34px 20px;
  background:
    linear-gradient(90deg, #e6edf8 0%, #f8fbff 34%, #d8e0ee 67%, #aebcd2 100%);
  box-shadow:
    inset -18px -18px 26px rgba(10, 19, 40, 0.08),
    0 30px 50px rgba(0, 0, 0, 0.24);
}

.hero-plane-body::before {
  content: "";
  position: absolute;
  right: 8%;
  top: 22px;
  width: 200px;
  height: 56px;
  background: linear-gradient(180deg, #0c2449, #0a1934);
  clip-path: polygon(0 0, 100% 10%, 100% 100%, 12% 100%);
}

.hero-plane-tail {
  position: absolute;
  left: 24%;
  bottom: 134px;
  width: 58px;
  height: 122px;
  background: linear-gradient(180deg, #1c3f78, #0c1f43);
  clip-path: polygon(34% 0, 100% 4%, 84% 100%, 0 100%);
}

.hero-plane-engine {
  position: absolute;
  bottom: 16px;
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, #141a23 0 18%, #3a4658 19% 33%, #0d1218 34% 43%, #c8d4e4 44% 100%);
  box-shadow: inset -10px -10px 18px rgba(0,0,0,0.18);
}

.hero-plane-engine.left { left: 31%; }
.hero-plane-engine.right { left: 51%; }

.hero-plane-title {
  position: absolute;
  left: 44%;
  bottom: 102px;
  color: #112850;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  font-size: 1.95rem;
  line-height: 0.88;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  opacity: 0.8;
  transform: rotate(-8deg);
}

.hero-footer-line {
  position: absolute;
  left: 56px;
  right: 48px;
  bottom: 26px;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  color: rgba(233, 240, 255, 0.74);
  font-size: 0.96rem;
}

.airline-panel {
  background:
    radial-gradient(circle at top left, rgba(68, 119, 209, 0.08), transparent 18%),
    linear-gradient(180deg, #f5f7fb 0%, #eef2f8 100%);
  display: grid;
  align-items: center;
  padding: 44px 40px;
}

.airline-card {
  max-width: 580px;
  width: 100%;
  margin: 0 auto;
  padding: 38px 38px 30px;
  border-radius: 26px;
  border: 1px solid rgba(19, 45, 88, 0.08);
  box-shadow: 0 24px 70px rgba(14, 29, 57, 0.14);
}

.login-card-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 26px;
}

.airline-head {
  text-align: center;
}

.airline-head h2 {
  font-size: 2.85rem;
  color: #112a55;
}

.airline-head p {
  max-width: 380px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.65;
}

.airline-form {
  gap: 18px;
}

.airline-form input {
  padding: 18px 18px;
  border-radius: 14px;
  font-size: 1.02rem;
  background: #ffffff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.form-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: -4px;
}

.remember-row {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  color: #5f6d86;
}

.remember-row input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.form-link {
  color: #2b62d0;
  font-weight: 600;
}

.airline-primary {
  padding: 17px 18px;
  border-radius: 12px;
  background: linear-gradient(180deg, #071a43, #081635);
  font-size: 1.14rem;
}

.secondary-button {
  border: 1px solid #cfdaee;
  border-radius: 12px;
  background: #ffffff;
  color: #102240;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.airline-secondary {
  padding: 16px 18px;
  margin-top: 2px;
}

.divider-line {
  position: relative;
  margin: 24px 0 18px;
  text-align: center;
}

.divider-line::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  background: #d9e2f1;
}

.divider-line span {
  position: relative;
  z-index: 1;
  padding: 0 14px;
  background: #fff;
  color: #7b879c;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
}

.eyebrow {
  display: inline-block;
  margin-bottom: 18px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #8ab8ff;
  font-size: 0.78rem;
}

.login-copy h1 {
  margin: 0 0 16px;
  max-width: 760px;
  font-family: "Rajdhani", sans-serif;
  font-size: 4rem;
  line-height: 0.96;
}

.login-copy p {
  max-width: 720px;
  font-size: 1.08rem;
  line-height: 1.65;
  color: rgba(230, 238, 255, 0.78);
}

.login-feature-grid {
  margin-top: 34px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.login-feature-grid article {
  padding: 18px 18px 20px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
  border: 1px solid rgba(255,255,255,0.08);
}

.login-feature-grid strong {
  display: block;
  margin-bottom: 8px;
  font-size: 1.08rem;
}

.login-feature-grid span {
  color: rgba(230, 238, 255, 0.7);
  line-height: 1.5;
}

.ops-preview {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.ops-preview-card {
  padding: 16px 18px 18px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(9, 23, 46, 0.88), rgba(8, 18, 36, 0.72));
  border: 1px solid rgba(133, 175, 241, 0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.ops-label {
  display: inline-block;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  color: #8ab8ff;
}

.ops-preview-card strong {
  display: block;
  font-size: 1.15rem;
  margin-bottom: 6px;
}

.ops-preview-card small {
  display: block;
  color: rgba(230, 238, 255, 0.7);
  line-height: 1.45;
  font-size: 0.92rem;
}

.login-panel {
  display: grid;
  align-items: center;
}

.login-card {
  padding: 30px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,250,255,0.98));
  color: var(--ink);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
}

.login-card-head h2 {
  margin: 0 0 8px;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
}

.login-card-head p {
  margin: 0 0 22px;
  color: var(--muted);
}

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

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

.login-form label span {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.76rem;
  color: var(--muted);
}

.login-form input {
  width: 100%;
  padding: 15px 16px;
  border-radius: 14px;
  border: 1px solid #cfdaee;
  background: #fbfdff;
  color: var(--ink);
  font: inherit;
  font-size: 1rem;
}

.login-form select {
  width: 100%;
  padding: 15px 16px;
  border-radius: 14px;
  border: 1px solid #cfdaee;
  background: #fbfdff;
  color: var(--ink);
  font: inherit;
  font-size: 1rem;
}

.login-form input:focus {
  outline: 2px solid rgba(44, 115, 218, 0.22);
  border-color: var(--blue-500);
}

.login-form select:focus {
  outline: 2px solid rgba(44, 115, 218, 0.22);
  border-color: var(--blue-500);
}

.primary-button {
  margin-top: 8px;
  padding: 15px 18px;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(180deg, #2675ea, #195ac3);
  color: white;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.primary-button--disabled,
.primary-button:disabled {
  background: linear-gradient(180deg, #c8d4e8, #b7c5dd);
  color: #5d718f;
  cursor: not-allowed;
}

.secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  border-radius: 14px;
  border: 1px solid #c9d8f0;
  background: linear-gradient(180deg, #ffffff, #f4f8ff);
  color: #174287;
  font: inherit;
  font-weight: 700;
  text-align: center;
}

.secondary-auth-button {
  margin-top: 10px;
}

.login-error {
  margin: 14px 0 0;
  color: #b12626;
  font-weight: 600;
}

.login-flash {
  margin: 14px 0 0;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid #d9e2f1;
  background: linear-gradient(180deg, #f8fbff, #f3f8ff);
}

.login-flash strong,
.login-flash span {
  display: block;
}

.login-flash strong {
  margin-bottom: 6px;
  color: #102240;
}

.login-flash span {
  color: #627089;
  line-height: 1.45;
}

.login-flash-success {
  border-color: rgba(33, 165, 88, 0.28);
  background: linear-gradient(180deg, #f3fff7, #ecfbf2);
}

.login-flash-success strong {
  color: #14703b;
}

.auth-switch {
  margin-top: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #6f7d95;
  font-size: 0.95rem;
}

.auth-switch a {
  color: var(--blue-500);
  font-weight: 700;
}

.prominent-auth-switch {
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  background: linear-gradient(180deg, #f8fbff, #f3f8ff);
  border: 1px solid #d9e2f1;
}

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

.form-help {
  margin: -2px 0 0;
  color: #6f7d95;
  font-size: 0.94rem;
  line-height: 1.5;
}

.demo-users {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.demo-users-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.demo-users-head span {
  color: var(--muted);
  font-size: 0.9rem;
}

.demo-user-list {
  display: grid;
  gap: 12px;
}

.demo-user {
  padding: 15px 16px;
  border-radius: 16px;
  border: 1px solid #d9e2f1;
  background: linear-gradient(180deg, #ffffff, #f6faff);
  text-align: left;
  cursor: pointer;
  color: var(--ink);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.demo-user:hover {
  transform: translateY(-1px);
  border-color: rgba(43, 98, 208, 0.35);
  box-shadow: 0 10px 24px rgba(24, 55, 103, 0.08);
}

.demo-user strong,
.demo-user span {
  display: block;
}

.demo-user span {
  margin-top: 4px;
  color: var(--muted);
}

.login-legal {
  margin-top: 20px;
  text-align: center;
  color: #7b879c;
  font-size: 0.94rem;
}

.login-note,
.empty-state {
  padding: 18px 20px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f8fbff, #f3f8ff);
  border: 1px solid #d9e2f1;
}

.login-note strong,
.empty-state strong {
  display: block;
  margin-bottom: 8px;
  color: #102240;
  font-size: 1.02rem;
}

.login-note span,
.empty-state span {
  color: #627089;
  line-height: 1.55;
}

.assignment-empty,
.side-empty {
  margin: 18px 22px 22px;
}

.table-note-pad {
  padding: 0 20px 18px;
}

.message-inline {
  display: grid;
  gap: 4px;
  padding: 12px 0;
  border-top: 1px solid var(--line);
}

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

.summary-grid--schedule {
  gap: 18px;
  padding-top: 6px;
}

.summary-tile {
  padding: 16px 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f8fbff, #f1f6ff);
  border: 1px solid #d9e2f1;
}

.summary-tile--schedule {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  min-height: 104px;
  padding: 20px 22px;
  border-radius: 22px;
  background:
    radial-gradient(circle at top left, rgba(118, 170, 255, 0.12), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-color: rgba(30, 68, 131, 0.12);
  box-shadow: 0 10px 28px rgba(15, 34, 66, 0.08);
}

.summary-tile-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #edf5ff, #dceafe);
  color: #2567d8;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.summary-tile-icon svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.summary-tile-body {
  min-width: 0;
}

.summary-tile span,
.schedule-meta-grid span,
.rule-item span {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.74rem;
  color: var(--muted);
}

.summary-tile strong,
.schedule-meta-grid strong,
.rule-item strong {
  display: block;
  margin-top: 8px;
  color: #102240;
  font-size: 1.1rem;
}

.summary-tile--schedule span {
  font-size: 0.82rem;
  letter-spacing: 0.05em;
  color: #536784;
}

.summary-tile--schedule strong {
  margin-top: 6px;
  font-size: 1.18rem;
  line-height: 1.2;
  color: #122d5a;
}

.schedule-layout {
  grid-template-columns: minmax(0, 1.65fr) minmax(320px, 0.85fr);
}

.schedule-side-panel {
  padding: 18px;
}

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

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

.rule-item {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}

.rule-item:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.route-map-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.leaflet-route-map {
  height: 360px;
  margin-bottom: 16px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(122, 140, 158, 0.28);
  background: linear-gradient(180deg, #dce6f5, #cdd9ec);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.leaflet-route-map-empty {
  display: grid;
  place-items: center;
  gap: 6px;
  padding: 22px;
  text-align: center;
  color: #4f6284;
}

.leaflet-route-map-empty strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.1rem;
  color: #18335f;
}

.company-base-network-map-shell {
  display: grid;
  gap: 14px;
}

.company-base-network-legend {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px;
  padding: 0 18px;
  color: #52627e;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.company-base-network-legend span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.company-base-network-legend__dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  display: inline-block;
}

.company-base-network-legend__dot--hub {
  background: #f59e0b;
  box-shadow: 0 0 0 2px rgba(247, 178, 59, 0.35);
}

.company-base-network-legend__dot--base {
  background: #0ea5e9;
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.28);
}

.company-base-network-map.leaflet-route-map {
  height: 460px;
  margin-bottom: 0;
}

.company-base-world-map.leaflet-route-map {
  height: 560px;
  margin-bottom: 0;
}

.company-base-map-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 18px;
}

.company-base-map-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 148px;
  padding: 10px 16px;
  border-radius: 14px;
  border: 1px solid rgba(44, 115, 218, 0.18);
  background: rgba(255, 255, 255, 0.92);
  color: #37557f;
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.company-base-map-tab:hover,
.company-base-map-tab:focus-visible {
  border-color: rgba(44, 115, 218, 0.42);
  background: rgba(240, 247, 255, 0.96);
  color: #1f4d90;
  box-shadow: 0 12px 24px rgba(44, 115, 218, 0.12);
}

.company-base-map-tab.is-active {
  border-color: rgba(28, 165, 104, 0.48);
  background: linear-gradient(180deg, rgba(232, 252, 242, 0.98), rgba(217, 247, 232, 0.96));
  color: #127145;
  box-shadow: 0 12px 24px rgba(28, 165, 104, 0.14);
}

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

.company-base-map-explainer__item {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border: 1px solid rgba(191, 211, 238, 0.8);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(249, 252, 255, 0.98), rgba(241, 247, 255, 0.94));
}

.company-base-map-explainer__item strong {
  color: var(--navy-850);
  font-family: "Rajdhani", sans-serif;
  font-size: 1.05rem;
  letter-spacing: 0.04em;
}

.company-base-map-explainer__item span {
  color: #536884;
  font-size: 0.95rem;
  line-height: 1.5;
}

.company-base-map-summary {
  margin: 0 0 14px;
  padding: 16px 18px 0;
  color: #536884;
  font-size: 0.98rem;
  line-height: 1.55;
}

@media (max-width: 900px) {
  .company-base-map-explainer {
    grid-template-columns: 1fr;
  }

  .company-base-map-tab {
    min-width: 0;
    flex: 1 1 220px;
  }
}

.route-map-tooltip {
  background: rgba(12, 28, 58, 0.92);
  color: #f6fbff;
  border: none;
  border-radius: 10px;
  padding: 4px 8px;
  box-shadow: 0 10px 24px rgba(12, 28, 58, 0.24);
  font-family: "Rajdhani", sans-serif;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.route-map-tooltip::before {
  border-top-color: rgba(12, 28, 58, 0.92);
}

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

.route-map-leg {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 12px;
}

.route-map-rail {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.route-map-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(180deg, #4ec3ff, #1b71ff);
  box-shadow: 0 0 0 4px rgba(78, 195, 255, 0.12);
  flex: 0 0 auto;
}

.route-map-line {
  width: 2px;
  flex: 1 1 auto;
  min-height: 36px;
  margin-top: 6px;
  background: linear-gradient(180deg, rgba(67, 126, 235, 0.75), rgba(67, 126, 235, 0.08));
}

.route-map-body {
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(247, 250, 255, 0.96), rgba(240, 246, 255, 0.92));
}

.route-map-topline,
.route-map-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
  flex-wrap: wrap;
}

.route-map-topline strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.15rem;
  letter-spacing: 0.03em;
  color: var(--navy-900);
}

.route-map-topline span {
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #2b63c0;
}

.route-map-meta {
  margin-top: 8px;
}

.route-map-meta span {
  font-size: 0.82rem;
  color: #61718d;
}

.section-title {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin: 0;
}

.section-title-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #f2f7ff, #e6efff);
  color: #2769dc;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.section-title-icon svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.main-panel {
  padding: 22px 24px 28px;
}

.topbar {
  background: linear-gradient(180deg, var(--navy-900), #0a1830 100%);
  color: #eef5ff;
  border-radius: 22px;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  box-shadow: var(--shadow);
}

.topbar-left,
.topbar-right {
  display: flex;
  align-items: center;
  gap: 22px;
  min-width: 0;
}

.topbar-right {
  margin-left: auto;
}

.icon-button {
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  display: grid;
  place-items: center;
  cursor: pointer;
}

.icon-button span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 2px 0;
  background: white;
  border-radius: 999px;
}

.top-links {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: flex-end;
}

.top-link-group {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 16px;
  padding-right: 18px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.top-link-group:last-child {
  padding-right: 0;
  border-right: none;
}

.top-link-group__label {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  color: rgba(166, 192, 232, 0.82);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.top-link {
  padding-bottom: 10px;
  border-bottom: 3px solid transparent;
  font-weight: 600;
  opacity: 0.86;
}

.top-link.active {
  opacity: 1;
  border-color: #ffffff;
}

.zulu-clock {
  display: flex;
  flex-direction: column;
  text-align: right;
}

.zulu-clock strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.3rem;
}

.zulu-clock span,
.profile-chip span {
  color: rgba(230, 239, 255, 0.72);
}

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

.profile-chip__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 0;
}

.profile-chip strong {
  display: block;
}

.profile-chip > div:last-child,
.airline-chip strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-chip__meta strong,
.profile-chip__meta span {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-chip__signout {
  display: inline-flex;
  align-self: flex-start;
  margin-top: 2px;
  color: #ff7676;
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1;
  text-transform: capitalize;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.profile-chip__signout:hover,
.profile-chip__signout:focus-visible {
  color: #ff9a9a;
}

.airline-chip,
.airline-badge,
.airline-inline-badge {
  --airline-start: #25497f;
  --airline-end: #10264b;
  --airline-accent: #8ab8ff;
}

.airline-chip,
.airline-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.04)),
    linear-gradient(135deg, var(--airline-start), var(--airline-end));
  color: #fff;
  box-shadow: 0 10px 24px rgba(3, 12, 28, 0.16);
}

.airline-chip {
  max-width: 230px;
  padding: 9px 12px;
  border-radius: 16px;
}

.airline-chip span,
.airline-badge span,
.airline-inline-badge {
  display: inline-grid;
  place-items: center;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.airline-chip__mark img,
.airline-badge__mark img,
.airline-brand-mark img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: inherit;
}

.airline-chip span {
  width: 36px;
  height: 36px;
  border-radius: 12px;
}

.airline-chip__mark.airline-brand-mark--has-image,
.airline-badge__mark.airline-brand-mark--has-image {
  padding: 0;
  overflow: hidden;
  background: #ffffff;
  border-color: rgba(255, 255, 255, 0.3);
}

.airline-chip strong {
  font-size: 0.9rem;
}

.airline-badge {
  align-self: start;
  max-width: 360px;
  padding: 10px 14px;
  border-radius: 18px;
}

.airline-badge span {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  font-size: 1.04rem;
}

.airline-badge strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.airline-inline-badge {
  width: 34px;
  height: 26px;
  border-radius: 9px;
  color: #fff;
  background: linear-gradient(135deg, var(--airline-start), var(--airline-end));
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 18px rgba(16, 38, 75, 0.14);
}

.airline-brand-mark {
  --airline-start: #25497f;
  --airline-end: #10264b;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  overflow: hidden;
  color: #ffffff;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: linear-gradient(135deg, var(--airline-start), var(--airline-end));
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 10px 20px rgba(16, 38, 75, 0.14);
}

.airline-brand-mark--has-image {
  padding: 0;
  background: #ffffff;
  border-color: rgba(203, 218, 243, 0.92);
}

.airline-theme-ua,
.airline-theme-ual {
  --airline-start: #1f4f8f;
  --airline-end: #13294b;
  --airline-accent: #7fb1ff;
}

.airline-theme-dl,
.airline-theme-dal {
  --airline-start: #c8102e;
  --airline-end: #182b57;
  --airline-accent: #e31b38;
}

.airline-theme-aa,
.airline-theme-aal {
  --airline-start: #0078d2;
  --airline-end: #b61f2e;
  --airline-accent: #d9e8f8;
}

.airline-theme-wn,
.airline-theme-swa {
  --airline-start: #304cb2;
  --airline-end: #d71920;
  --airline-accent: #f9c80e;
}

.airline-theme-b6,
.airline-theme-jbu {
  --airline-start: #003876;
  --airline-end: #00a6d6;
  --airline-accent: #7ed6f5;
}

.airline-theme-as,
.airline-theme-asa {
  --airline-start: #01426a;
  --airline-end: #0b5e7e;
  --airline-accent: #66c4df;
}

.airline-theme-nk,
.airline-theme-nks {
  --airline-start: #ffe600;
  --airline-end: #1f1f1f;
  --airline-accent: #ffe600;
  color: #101820;
}

.airline-theme-f9,
.airline-theme-fft {
  --airline-start: #167a3a;
  --airline-end: #064c2d;
  --airline-accent: #8bd36b;
}

.airline-theme-ac,
.airline-theme-aca {
  --airline-start: #d71920;
  --airline-end: #111111;
  --airline-accent: #f1f1f1;
}

.airline-theme-ba,
.airline-theme-baw {
  --airline-start: #2e5aa7;
  --airline-end: #c8102e;
  --airline-accent: #ffffff;
}

.profile-avatar {
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.26), rgba(255, 255, 255, 0.05)),
    linear-gradient(145deg, #2a518f, #17335d);
  border: 3px solid rgba(255, 255, 255, 0.18);
}

.profile-avatar.small {
  width: 54px;
  height: 54px;
  font-size: 1.2rem;
}

.profile-avatar.large {
  width: 104px;
  height: 104px;
  font-size: 2rem;
}

.rank-id-card {
  width: 104px;
  min-height: 126px;
  padding: 12px 10px 14px;
  border-radius: 16px;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 8px;
  color: #fff;
  text-align: center;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #2b3562, #1b2548);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 16px 28px rgba(12, 24, 50, 0.16);
}

.rank-id-card__clip {
  width: 22px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.65);
  border-bottom: 0;
  margin-bottom: 2px;
}

.rank-id-card__stripes {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 100%;
  max-width: 58px;
}

.rank-id-card__stripes span {
  display: block;
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08);
}

.rank-id-card strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.rank-id-card span {
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(237, 243, 255, 0.82);
}

.rank-id-card--cadet {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #384c83, #223964);
}

.rank-id-card--second-officer {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #315e91, #22446d);
}

.rank-id-card--first-officer {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #20608b, #144e79);
}

.rank-id-card--captain {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #4b336f, #2e1f4a);
}

.rank-id-card--senior-captain {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #5a2b46, #3a1831);
}

.content-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1.75fr) minmax(300px, 0.75fr);
  gap: 16px;
}

.primary-column,
.secondary-column {
  display: grid;
  gap: 16px;
  align-content: start;
}

.dashboard-v2 {
  display: grid;
  gap: 18px;
  margin-top: 16px;
}

.dashboard-v2__hero-row {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 1.55fr) minmax(300px, 0.9fr);
  gap: 18px;
}

.dashboard-v2__module-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.dashboard-v2__lower-row {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.45fr);
  gap: 18px;
}

.dashboard-v2__status-card,
.dashboard-v2__flight-card,
.dashboard-v2__actions-card,
.dashboard-v2__module-card,
.dashboard-v2__messages-card,
.dashboard-v2__tracker-card {
  padding: 20px 22px;
}

.dashboard-v2__card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.dashboard-v2__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #183562;
}

.dashboard-v2__status-pill,
.dashboard-v2__mini-badge,
.dashboard-v2__countdown {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

.dashboard-v2__mini-badge,
.dashboard-v2__countdown {
  background: #edf4ff;
  color: #2d63cb;
}

.dashboard-v2__status-pill {
  background: #eef8f1;
}

.dashboard-v2__status-card h1,
.dashboard-v2__tracker-copy strong {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: clamp(2rem, 2.8vw, 3rem);
  line-height: 0.96;
  color: #15315d;
}

.dashboard-v2__status-card p {
  margin: 10px 0 18px;
  color: #667792;
  font-size: 1.02rem;
  line-height: 1.6;
}

.dashboard-v2__status-metrics,
.dashboard-v2__flight-meta,
.dashboard-v2__mini-stats,
.dashboard-v2__logbook-grid,
.dashboard-v2__tracker-stats {
  display: grid;
  gap: 14px;
}

.dashboard-v2__status-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 18px;
  border: 1px solid #dbe6f7;
  border-radius: 18px;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
}

.dashboard-v2__status-metrics article,
.dashboard-v2__flight-meta article,
.dashboard-v2__mini-stats div,
.dashboard-v2__logbook-grid div,
.dashboard-v2__tracker-stats div {
  min-width: 0;
}

.dashboard-v2__status-metrics span,
.dashboard-v2__flight-meta span,
.dashboard-v2__mini-stats span,
.dashboard-v2__logbook-grid span,
.dashboard-v2__tracker-stats span,
.dashboard-v2__training-copy span,
.dashboard-v2__training-copy small,
.dashboard-v2__achievement-copy span,
.dashboard-v2__achievement-copy small,
.dashboard-v2__message-feature span,
.dashboard-v2__message-list span {
  display: block;
  color: #70819b;
}

.dashboard-v2__status-metrics span,
.dashboard-v2__flight-meta span,
.dashboard-v2__mini-stats span,
.dashboard-v2__logbook-grid span,
.dashboard-v2__tracker-stats span {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.dashboard-v2__status-metrics strong,
.dashboard-v2__flight-meta strong,
.dashboard-v2__mini-stats strong,
.dashboard-v2__logbook-grid strong,
.dashboard-v2__tracker-stats strong {
  display: block;
  margin-top: 6px;
  color: #17315e;
  font-size: 1.12rem;
}

.dashboard-v2__status-metrics small {
  display: block;
  margin-top: 4px;
  color: #7788a4;
  font-size: 0.82rem;
}

.dashboard-v2__flight-pills {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-v2__flight-route {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 96px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border: 1px solid #dce7f7;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
}

.dashboard-v2__flight-route strong {
  display: block;
  font-family: "Rajdhani", sans-serif;
  font-size: clamp(2rem, 2.8vw, 3rem);
  line-height: 0.9;
  color: #17315e;
}

.dashboard-v2__flight-route span {
  display: block;
  margin-top: 6px;
  color: #6d7e97;
}

.dashboard-v2__flight-route > div:last-child {
  text-align: right;
}

.dashboard-v2__flight-connector {
  position: relative;
  min-height: 36px;
}

.dashboard-v2__flight-connector i {
  position: absolute;
  inset: 50% 0 auto;
  height: 0;
  border-top: 2px dashed #b5cdf6;
}

.dashboard-v2__flight-connector em {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -58%);
  font-style: normal;
  font-size: 1.5rem;
  color: #2d63cb;
  background: #fff;
  padding: 0 8px;
}

.dashboard-v2__flight-meta {
  margin-top: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dashboard-v2__footer-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #ffffff, #f6faff);
  color: #2156ba;
  font-weight: 700;
}

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

.dashboard-v2__actions-grid a,
.dashboard-v2__tracker-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 90px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid #d9e3f3;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
  color: #2358bb;
  font-weight: 700;
  text-align: center;
}

.dashboard-v2__tracker-link {
  min-height: 62px;
  margin-top: 12px;
  justify-content: space-between;
}

.dashboard-v2__training-wrap {
  display: grid;
  grid-template-columns: 136px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.dashboard-v2__training-ring {
  width: 132px;
  height: 132px;
}

.dashboard-v2__training-copy {
  display: grid;
  gap: 8px;
}

.dashboard-v2__training-copy strong,
.dashboard-v2__achievement-copy strong,
.dashboard-v2__message-feature strong,
.dashboard-v2__message-list strong {
  color: #17315e;
  font-size: 1.28rem;
}

.dashboard-v2__training-copy .outline-button {
  margin-top: 8px;
  width: fit-content;
}

.dashboard-v2__money-total {
  font-family: "Rajdhani", sans-serif;
  font-size: clamp(2.2rem, 3vw, 3.2rem);
  line-height: 0.92;
  color: #18a33f;
}

.dashboard-v2__money-subtext {
  margin-top: 8px;
  color: #6c7d97;
}

.dashboard-v2__mini-stats,
.dashboard-v2__logbook-grid {
  margin-top: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dashboard-v2__logbook-grid strong {
  font-size: 1.35rem;
}

.dashboard-v2__logbook-grid--secondary {
  margin-top: 10px;
}

.dashboard-v2__achievement {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.dashboard-v2__achievement-badge {
  width: 120px;
  height: 120px;
  border-radius: 26px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #0f2650, #183f79);
  color: #f8fbff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}

.dashboard-v2__achievement-badge span {
  font-size: 2.7rem;
}

.dashboard-v2__achievement-progress {
  height: 8px;
  margin: 12px 0 8px;
  border-radius: 999px;
  background: #e4edf8;
  overflow: hidden;
}

.dashboard-v2__achievement-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #29ca68, #49a6ff);
}

.dashboard-v2__messages-card {
  display: flex;
  flex-direction: column;
}

.dashboard-v2__message-feature {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fbfdff, #f7fbff);
}

.dashboard-v2__message-list {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.dashboard-v2__message-list article {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-top: 1px solid #e4ecf8;
}

.dashboard-v2__message-list article:first-child {
  border-top: 0;
}

.dashboard-v2__tracker-card {
  background: linear-gradient(180deg, #0b1830, #0f2345 100%);
  color: #eef5ff;
  overflow: hidden;
}

.dashboard-v2__tracker-card .dashboard-v2__eyebrow,
.dashboard-v2__tracker-card strong,
.dashboard-v2__tracker-card .dashboard-v2__tracker-route,
.dashboard-v2__tracker-card .dashboard-v2__tracker-stats strong {
  color: #f4f8ff;
}

.dashboard-v2__tracker-summary {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
}

.dashboard-v2__tracker-copy {
  display: grid;
  gap: 14px;
}

.dashboard-v2__tracker-route {
  font-family: "Rajdhani", sans-serif;
  font-size: 2.1rem;
  line-height: 0.95;
}

.dashboard-v2__tracker-route em {
  font-style: normal;
  color: #85c0ff;
}

.dashboard-v2__tracker-card .dashboard-v2__tracker-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dashboard-v2__tracker-card .dashboard-v2__tracker-stats span {
  color: rgba(223, 232, 248, 0.68);
}

.dashboard-v2__tracker-map {
  height: 280px;
  margin: 0;
  border-radius: 22px;
}

@media (max-width: 1560px) {
  .dashboard-v2__hero-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.4fr);
  }

  .dashboard-v2__actions-card {
    grid-column: 1 / -1;
  }

  .dashboard-v2__actions-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .dashboard-v2__tracker-summary {
    grid-template-columns: 240px minmax(0, 1fr);
  }
}

@media (max-width: 1320px) {
  .dashboard-v2__module-row,
  .dashboard-v2__lower-row,
  .dashboard-v2__hero-row {
    grid-template-columns: 1fr;
  }

  .dashboard-v2__actions-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .dashboard-v2__status-metrics,
  .dashboard-v2__flight-meta,
  .dashboard-v2__mini-stats,
  .dashboard-v2__logbook-grid,
  .dashboard-v2__tracker-card .dashboard-v2__tracker-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-v2__flight-route,
  .dashboard-v2__training-wrap,
  .dashboard-v2__achievement,
  .dashboard-v2__tracker-summary {
    grid-template-columns: 1fr;
  }

  .dashboard-v2__flight-route > div:last-child {
    text-align: left;
  }
}

@media (max-width: 620px) {
  .dashboard-v2__status-metrics,
  .dashboard-v2__flight-meta,
  .dashboard-v2__mini-stats,
  .dashboard-v2__logbook-grid,
  .dashboard-v2__actions-grid,
  .dashboard-v2__tracker-card .dashboard-v2__tracker-stats {
    grid-template-columns: 1fr;
  }
}

.card {
  background: linear-gradient(180deg, #ffffff 0%, #fdfefe 100%);
  border: 1px solid rgba(17, 39, 77, 0.08);
  border-radius: 22px;
  box-shadow: 0 10px 26px rgba(14, 29, 57, 0.08);
  overflow: hidden;
}

.card.dashboard-v2__status-card,
.card.dashboard-v2__flight-card,
.card.dashboard-v2__actions-card,
.card.dashboard-v2__module-card,
.card.dashboard-v2__messages-card {
  background:
    radial-gradient(circle at top right, rgba(118, 171, 255, 0.14), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(23, 49, 94, 0.08);
  box-shadow: 0 14px 36px rgba(14, 29, 57, 0.08);
}

.card.dashboard-v2__status-card {
  position: relative;
  min-height: 300px;
}

.card.dashboard-v2__status-card::after {
  content: "";
  position: absolute;
  right: -24px;
  bottom: -8px;
  width: 240px;
  height: 140px;
  background:
    linear-gradient(180deg, rgba(23, 49, 94, 0.08), rgba(23, 49, 94, 0)),
    radial-gradient(circle at 50% 50%, rgba(48, 92, 170, 0.1), transparent 58%);
  clip-path: polygon(0 72%, 52% 26%, 100% 72%, 100% 100%, 0 100%);
  pointer-events: none;
}

.dashboard-v2__status-card h1 {
  max-width: 14ch;
  font-size: clamp(1.9rem, 2.4vw, 2.8rem);
}

.dashboard-v2__status-card p {
  max-width: 54ch;
}

.dashboard-v2__status-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 16px 18px;
}

.dashboard-v2__status-metrics strong {
  font-size: 1.02rem;
}

.card.dashboard-v2__flight-card {
  position: relative;
  min-height: 300px;
}

.card.dashboard-v2__flight-card::after {
  content: "";
  position: absolute;
  top: 54px;
  right: 18px;
  width: 14px;
  height: 208px;
  border-radius: 2px;
  background:
    repeating-linear-gradient(
      180deg,
      rgba(16, 34, 64, 0.96) 0 4px,
      transparent 4px 7px
    );
  opacity: 0.7;
}

.dashboard-v2__flight-route {
  padding: 18px 22px 14px;
  margin-right: 28px;
}

.dashboard-v2__flight-route strong {
  font-size: clamp(2.2rem, 2.8vw, 3.3rem);
}

.dashboard-v2__flight-route span {
  font-size: 0.98rem;
  line-height: 1.25;
  max-width: 15ch;
}

.dashboard-v2__flight-meta {
  margin-right: 28px;
}

.dashboard-v2__flight-meta strong {
  font-size: 1rem;
}

.card.dashboard-v2__actions-card {
  min-height: 300px;
}

/* Dashboard v2 cleanup pass */
.dashboard-v2__hero-row {
  grid-template-columns: minmax(0, 1.38fr) minmax(420px, 1.08fr);
  align-items: stretch;
}

.dashboard-v2__map-card,
.dashboard-v2__progress-card {
  background:
    radial-gradient(circle at top right, rgba(118, 171, 255, 0.14), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(23, 49, 94, 0.08);
  box-shadow: 0 14px 36px rgba(14, 29, 57, 0.08);
}

.dashboard-v2__map-card,
.dashboard-v2__progress-card,
.dashboard-v2__module-card,
.dashboard-v2__flight-card {
  padding: 20px 22px;
}

.dashboard-v2__flight-card {
  min-height: 0;
}

.dashboard-v2__map-card {
  display: flex;
  flex-direction: column;
}

.dashboard-v2__map-canvas {
  flex: 1 1 auto;
  min-height: 325px;
  height: 100%;
  margin: 0;
  border-radius: 22px;
}

.dashboard-v2__module-card {
  min-height: 330px;
}

.dashboard-v2__message-feature {
  min-height: 112px;
}

.dashboard-v2__message-list {
  margin-top: 12px;
}

.dashboard-v2__progress-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dashboard-v2__progress-card {
  min-height: 270px;
}

.dashboard-v2__progress-wrap {
  display: grid;
  grid-template-columns: 144px minmax(0, 1fr);
  gap: 22px;
  align-items: center;
}

.dashboard-v2__progress-copy {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.dashboard-v2__progress-copy strong {
  color: #17315e;
  font-size: 1.22rem;
  line-height: 1.15;
}

.dashboard-v2__progress-copy span,
.dashboard-v2__progress-copy small {
  display: block;
  color: #70819b;
  line-height: 1.45;
}

.dashboard-v2__progress-copy .outline-button {
  margin-top: 10px;
  width: fit-content;
}

@media (max-width: 1560px) {
  .dashboard-v2__hero-row {
    grid-template-columns: minmax(0, 1.24fr) minmax(360px, 1fr);
  }
}

@media (max-width: 1320px) {
  .dashboard-v2__hero-row,
  .dashboard-v2__module-row,
  .dashboard-v2__progress-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .dashboard-v2__progress-wrap {
    grid-template-columns: 1fr;
  }
}

.dashboard-v2__actions-grid a {
  position: relative;
  min-height: 88px;
  padding-top: 26px;
}

.dashboard-v2__actions-grid a::before {
  content: "";
  position: absolute;
  top: 16px;
  left: 50%;
  width: 18px;
  height: 18px;
  margin-left: -9px;
  border-radius: 6px;
  border: 2px solid #2d63cb;
  opacity: 0.8;
}

.dashboard-v2__tracker-link {
  min-height: 58px;
}

.dashboard-v2__module-row {
  align-items: stretch;
}

.card.dashboard-v2__module-card,
.card.dashboard-v2__messages-card {
  min-height: 290px;
}

.dashboard-v2__training-wrap {
  grid-template-columns: 118px minmax(0, 1fr);
}

.dashboard-v2__training-ring {
  width: 112px;
  height: 112px;
}

.dashboard-v2__training-copy strong {
  font-size: 1.1rem;
}

.dashboard-v2__training-copy .outline-button,
.dashboard-v2__footer-link {
  min-height: 50px;
}

.dashboard-v2__money-total {
  font-size: clamp(2rem, 2.7vw, 2.9rem);
}

.dashboard-v2__mini-stats,
.dashboard-v2__logbook-grid {
  gap: 12px 16px;
}

.dashboard-v2__logbook-grid strong {
  font-size: 1.18rem;
}

.dashboard-v2__achievement {
  grid-template-columns: 92px minmax(0, 1fr);
  align-items: start;
}

.dashboard-v2__achievement-badge {
  width: 92px;
  height: 92px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, #dfe7f6 0%, #b6c8e6 45%, #f5f8fe 100%);
  color: #214a92;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.85);
}

.dashboard-v2__achievement-badge span {
  font-size: 2.15rem;
}

.dashboard-v2__achievement-copy strong {
  font-size: 1.12rem;
}

.card.dashboard-v2__messages-card {
  min-height: 280px;
}

.dashboard-v2__message-feature {
  min-height: 92px;
}

.card.dashboard-v2__tracker-card {
  background:
    linear-gradient(180deg, #08182f 0%, #0d2243 100%);
  border: 1px solid rgba(107, 154, 228, 0.18);
  box-shadow: 0 18px 40px rgba(6, 18, 40, 0.24);
}

.dashboard-v2__tracker-summary {
  grid-template-columns: 300px minmax(0, 1fr);
}

.dashboard-v2__tracker-copy {
  padding: 8px 4px 8px 2px;
}

.dashboard-v2__tracker-copy strong {
  font-size: 2.35rem;
}

.dashboard-v2__tracker-route {
  font-size: 1.95rem;
}

.dashboard-v2__tracker-card .dashboard-v2__tracker-stats strong {
  font-size: 1rem;
}

.dashboard-v2__tracker-map-wrap {
  min-width: 0;
}

.dashboard-v2__tracker-map {
  height: 252px;
  border-radius: 18px;
  border: 1px solid rgba(143, 185, 245, 0.16);
}

.dashboard-v2__tracker-card .leaflet-control-attribution {
  font-size: 0.66rem;
}

.dashboard-v2 .empty-state {
  margin: 0;
  padding: 18px;
  border: 1px solid #dce6f5;
  border-radius: 18px;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
}

.hero-card {
  padding: 22px;
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 18px;
}

.hero-identity {
  position: relative;
  display: grid;
  place-items: center;
}

.presence-dot {
  position: absolute;
  right: 18px;
  bottom: 10px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #1bc45c;
  border: 3px solid white;
}

.hero-content h1 {
  margin: 0 0 14px;
  font-size: 2.2rem;
  color: #1b2f60;
}

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

.airline-logo-card {
  max-width: 320px;
  min-width: 212px;
  min-height: 76px;
  padding: 14px 18px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: #ffffff;
  border: 1px solid rgba(18, 36, 64, 0.08);
  box-shadow: 0 14px 26px rgba(12, 28, 54, 0.12);
}

.airline-logo-card__mark {
  flex: 0 0 auto;
}

.airline-logo-card__copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.airline-logo-card__copy strong,
.airline-logo-card__copy span {
  display: block;
}

.airline-logo-card__copy strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.55rem;
  line-height: 0.95;
  letter-spacing: 0.06em;
  color: #102240;
}

.airline-logo-card__copy span {
  color: #5e6b86;
  font-size: 0.88rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.airline-logo-card--delta .airline-logo-card__mark {
  width: 34px;
  height: 42px;
  position: relative;
}

.airline-logo-card__mark--delta span,
.airline-logo-card__mark--delta::before {
  content: "";
  position: absolute;
  left: 0;
  width: 0;
  height: 0;
  border-left: 17px solid transparent;
  border-right: 17px solid transparent;
}

.airline-logo-card__mark--delta span {
  top: 0;
  border-bottom: 24px solid #c8102e;
}

.airline-logo-card__mark--delta::before {
  bottom: 0;
  border-top: 13px solid #143d8d;
}

.airline-logo-card--delta .airline-logo-card__copy strong {
  color: #15315d;
}

.airline-logo-card--delta .airline-logo-card__copy span {
  text-transform: none;
  letter-spacing: 0.02em;
  font-size: 0.94rem;
  color: #4a5876;
}

.airline-logo-card--fedex .airline-logo-card__copy strong {
  font-family: "Barlow", sans-serif;
  font-size: 2rem;
  letter-spacing: -0.04em;
  color: #ff6600;
}

.airline-logo-card--fedex .airline-logo-card__copy strong em {
  color: #4d148c;
  font-style: normal;
}

.airline-logo-card--fedex .airline-logo-card__copy span {
  text-transform: none;
  letter-spacing: 0;
}

.airline-logo-card__mark--generic {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.05em;
  color: #fff;
  background: linear-gradient(145deg, #315e91, #1b355d);
}

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.metric-block {
  padding: 16px 20px;
  min-width: 0;
}

.metric-block + .metric-block {
  border-left: 1px solid var(--line);
}

.metric-block span,
.hero-footer span,
.route-stats span,
.flight-facts span,
.fatigue-stats span,
.roster-grid span,
.weather-row span,
.section-label,
.progress-top span,
.progress-metrics span,
.message-list span,
.table-note,
th {
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.74rem;
  color: var(--muted);
}

.metric-block strong {
  margin-top: 6px;
  display: block;
  font-size: 1.65rem;
}

.hero-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  padding-top: 14px;
  color: #31466f;
  font-weight: 500;
}

.status-good {
  color: var(--green-500);
}

.status-info {
  color: var(--blue-500);
}

.status-warn {
  color: #d49011;
}

.card-ribbon,
.side-header {
  background: linear-gradient(180deg, var(--navy-900), var(--navy-850));
  color: white;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.card-ribbon span:first-child,
.side-header h2 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.pill {
  border-radius: 999px;
  padding: 8px 14px;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
}

.pill.success {
  background: linear-gradient(180deg, #34cc67, #179e48);
}

.assignment-grid {
  padding: 22px;
  display: grid;
  grid-template-columns: 1.15fr 1fr 0.95fr;
  gap: 22px;
}

.assignment-aircraft,
.route-panel,
.flight-facts {
  min-width: 0;
}

.flight-number {
  font-family: "Rajdhani", sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #193163;
}

.aircraft-type,
.tail-meta {
  color: #52627e;
}

.assignment-route-graphic {
  margin: 12px 0;
  padding: 12px 14px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f7faff 0%, #eef4fc 100%);
  border: 1px solid rgba(153, 180, 222, 0.5);
}

.assignment-route-graphic__points {
  display: grid;
  grid-template-columns: minmax(64px, auto) minmax(0, 1fr) minmax(64px, auto);
  gap: 12px;
  align-items: center;
}

.assignment-route-graphic__stop strong,
.assignment-route-graphic__stop span {
  display: block;
}

.assignment-route-graphic__stop strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.3rem;
  color: #193163;
}

.assignment-route-graphic__stop span {
  margin-top: 2px;
  color: #52627e;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.assignment-route-graphic__stop:last-child {
  text-align: right;
}

.assignment-route-graphic__line {
  position: relative;
  min-height: 54px;
}

.assignment-route-graphic__track {
  position: absolute;
  left: 0;
  right: 0;
  top: 25px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #2e7cff 0%, #19b4ff 55%, #2e7cff 100%);
  box-shadow: 0 0 0 6px rgba(41, 122, 255, 0.08);
}

.assignment-route-graphic__line::before,
.assignment-route-graphic__line::after {
  content: "";
  position: absolute;
  top: 18px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ffffff;
  border: 4px solid #2e7cff;
}

.assignment-route-graphic__line::before {
  left: -1px;
}

.assignment-route-graphic__line::after {
  right: -1px;
}

.assignment-route-graphic__plane {
  position: absolute;
  left: 50%;
  top: 2px;
  transform: translateX(-50%);
  color: #1d61cb;
  font-size: 1.5rem;
  line-height: 1;
}

.assignment-route-graphic__distance {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  padding: 3px 10px;
  border-radius: 999px;
  background: #ffffff;
  color: #1d61cb;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 8px 14px rgba(17, 59, 124, 0.08);
}

.assignment-route-graphic__meta {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: #52627e;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.assignment-route-map.leaflet-route-map {
  height: 260px;
  margin: 12px 0;
  border-radius: 18px;
}

.assignment-route-map.leaflet-route-map-empty {
  min-height: 260px;
}

.tail-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
  font-size: 0.95rem;
}

.route-panel {
  padding: 0 10px;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
}

.route-points {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-bottom: 18px;
}

.route-points strong {
  display: block;
  font-family: "Rajdhani", sans-serif;
  font-size: 3rem;
  line-height: 1;
}

.route-points span {
  color: #61718d;
}

.route-arrow {
  font-size: 2.2rem;
  color: #6e88b7;
}

.route-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.route-stats strong,
.flight-facts strong,
.weather-row strong,
.fatigue-stats strong,
.roster-grid strong,
.progress-metrics strong,
.progress-top strong {
  display: block;
  margin-top: 6px;
  font-size: 1.3rem;
  color: #172d58;
}

.flight-facts {
  display: grid;
  gap: 12px;
}

.assignment-footer {
  border-top: 1px solid var(--line);
  padding: 16px 22px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.mini-weather-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 26px;
}

.mini-weather-strip span {
  display: block;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.74rem;
}

.mini-weather-strip strong {
  display: block;
  margin-top: 6px;
}

.outline-button {
  white-space: nowrap;
  padding: 12px 18px;
  border-radius: 12px;
  border: 1px solid #9db8e7;
  background: #ffffff;
  color: var(--blue-500);
  font-weight: 700;
  font: inherit;
  cursor: pointer;
}

.flash-banner {
  margin-bottom: 18px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #d9e2f1;
  display: grid;
  gap: 6px;
}

.flash-banner strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.08rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.flash-banner span {
  color: #4f6284;
  line-height: 1.55;
}

.flash-success {
  background: linear-gradient(180deg, #f5fcf7, #edf9f0);
  border-color: #bee7cb;
}

.flash-success strong {
  color: #0e8e45;
}

.flash-error {
  background: linear-gradient(180deg, #fff7f7, #fff1f1);
  border-color: #efcbcb;
}

.flash-error strong {
  color: #c03838;
}

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

.card-header {
  padding: 16px 18px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.card-header h2 {
  margin: 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.24rem;
  text-transform: uppercase;
  color: #17315e;
}

.card-header a,
.legal-line a {
  color: var(--blue-500);
  font-weight: 700;
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

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

.card-actions--schedule {
  gap: 12px 16px;
}

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

.roster-action-form {
  display: flex;
  align-items: end;
  gap: 10px;
}

.inline-action-label {
  display: block;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 700;
}

.inline-action-select {
  min-width: 118px;
  border-radius: 12px;
  border: 1px solid #d7e2f2;
  padding: 12px 14px;
  font: inherit;
  color: #18335f;
  background: rgba(252, 253, 255, 0.98);
}

.inline-action-input {
  min-width: 220px;
  border-radius: 12px;
  border: 1px solid #d7e2f2;
  padding: 12px 14px;
  font: inherit;
  color: #18335f;
  background: rgba(252, 253, 255, 0.98);
  box-shadow: inset 0 1px 2px rgba(20, 38, 72, 0.03);
}

.inline-action-input:focus,
.inline-action-select:focus {
  outline: none;
  border-color: #7ba5ed;
  box-shadow: 0 0 0 3px rgba(51, 104, 197, 0.14);
}

.schedule-generate-form {
  display: flex;
  align-items: flex-end;
  gap: 14px;
  flex-wrap: wrap;
  padding: 6px 0;
}

.schedule-generate-input-shell {
  display: block;
  padding: 10px 14px 12px;
  border-radius: 18px;
  border: 1px solid rgba(26, 63, 123, 0.12);
  background: linear-gradient(180deg, #ffffff, #f7fbff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.schedule-generate-form .inline-action-label {
  margin-bottom: 6px;
  color: #526784;
}

.schedule-generate-select {
  min-width: 156px;
  width: auto;
  border-radius: 14px;
  padding: 12px 42px 12px 16px;
  font-weight: 700;
  color: #183764;
}

.schedule-generate-button {
  width: auto;
  min-height: 54px;
  padding: 0 24px;
  border-radius: 16px;
  box-shadow: 0 14px 30px rgba(33, 96, 202, 0.24);
}

.card-header-note {
  color: #6a7a94;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.message-filter-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.filter-pill {
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid #d5e1f4;
  color: #5a6f92;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: #f8fbff;
}

.filter-pill.active {
  border-color: #8fb0e9;
  background: linear-gradient(180deg, #eef5ff, #e3eeff);
  color: #1e4ea7;
}

.messages-page-card {
  overflow: hidden;
}

.message-feed {
  padding: 0 18px 18px;
  display: grid;
  gap: 16px;
}

.message-card {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
}

.message-card-unread {
  border-color: #afcaef;
  box-shadow: 0 12px 28px rgba(28, 58, 107, 0.08);
}

.message-card-read {
  opacity: 0.96;
}

.message-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}

.message-card-head h3 {
  margin: 6px 0 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.48rem;
  color: #17315e;
}

.message-category {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(38, 117, 234, 0.11);
  color: #2157b4;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.message-head-meta {
  display: grid;
  justify-items: end;
  gap: 8px;
  min-width: 180px;
}

.message-head-meta small,
.message-card-foot span,
.message-read-stamp {
  color: #64748f;
  line-height: 1.5;
}

.message-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.status-unread {
  background: linear-gradient(180deg, #edf5ff, #deebff);
  color: #2053ad;
}

.status-read {
  background: linear-gradient(180deg, #f1f7f3, #e5f2e8);
  color: #20844a;
}

.message-card p {
  margin: 0 0 14px;
  color: #314869;
  line-height: 1.72;
}

.message-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

table {
  width: calc(100% - 36px);
  margin: 0 18px 12px;
  border-collapse: collapse;
}

.schedule-table {
  border-collapse: separate;
  border-spacing: 0;
}

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

td {
  color: #284063;
}

.schedule-table thead th {
  padding-top: 16px;
  padding-bottom: 16px;
  color: #5a6f90;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.schedule-table tbody td {
  padding-top: 14px;
  padding-bottom: 14px;
  background: rgba(255, 255, 255, 0.86);
  transition: background-color 0.18s ease;
}

.schedule-row:hover td {
  background: #f7fbff;
}

.schedule-table-pairing,
.schedule-table-flight,
.schedule-table-route {
  color: #17315e;
}

.schedule-table-pairing,
.schedule-table-flight {
  font-weight: 700;
}

.schedule-row td:first-child {
  border-left: 4px solid transparent;
}

.schedule-row--completed td:first-child {
  border-left-color: #31b768;
}

.schedule-row--next td:first-child {
  border-left-color: #f3ad23;
}

.schedule-row--scheduled td:first-child {
  border-left-color: #2c73da;
}

.schedule-row--active td:first-child {
  border-left-color: #7a5cff;
}

.schedule-row--cancelled td:first-child {
  border-left-color: #ef6b6b;
}

.schedule-status-summary {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.status-summary-pill,
.schedule-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  font-weight: 700;
  white-space: nowrap;
}

.status-summary-pill {
  padding: 9px 14px;
  border: 1px solid #dbe6f6;
  background: #ffffff;
  color: #41597f;
  box-shadow: 0 6px 16px rgba(20, 38, 72, 0.05);
}

.status-summary-pill i {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  display: inline-block;
}

.status-summary-pill--completed i { background: #31b768; }
.status-summary-pill--scheduled i { background: #2c73da; }
.status-summary-pill--next i { background: #f3ad23; }
.status-summary-pill--active i { background: #7a5cff; }

.schedule-status-pill {
  padding: 8px 12px;
  border: 1px solid transparent;
}

.schedule-status-pill__icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.schedule-status-pill__icon svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.schedule-status-pill--completed {
  background: #e9f8ef;
  border-color: #c4ebd1;
  color: #178a49;
}

.schedule-status-pill--scheduled {
  background: #edf4ff;
  border-color: #cfe0ff;
  color: #215fc9;
}

.schedule-status-pill--next {
  background: #fff6e5;
  border-color: #f7dfad;
  color: #cb8100;
}

.schedule-status-pill--active {
  background: #f0ebff;
  border-color: #d7caff;
  color: #6242d8;
}

.schedule-status-pill--cancelled {
  background: #ffeded;
  border-color: #f5c7c7;
  color: #c44545;
}

tbody tr:last-child td {
  border-bottom: 0;
}

.status-next {
  color: var(--green-500);
  font-weight: 700;
}

.table-note {
  padding: 0 18px 18px;
}

.check-list {
  list-style: none;
  margin: 0;
  padding: 0 18px 18px;
  display: grid;
  gap: 14px;
}

.check-list li {
  display: flex;
  gap: 12px;
  align-items: start;
}

.check-list strong {
  display: block;
}

.check-list small {
  display: block;
  margin-top: 4px;
  color: #67748e;
}

.ok,
.warn {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  margin-top: 3px;
  flex: 0 0 auto;
}

.ok { background: linear-gradient(180deg, #33cf68, #18a64f); }
.warn { background: linear-gradient(180deg, #f7cb62, #e9a634); }

.progress-card,
.messages-card {
  padding-bottom: 18px;
}

.progress-top,
.progress-metrics {
  padding: 0 18px;
}

.progress-top {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 16px;
}

.progress-bar {
  margin: 0 18px 16px;
  height: 12px;
  border-radius: 999px;
  background: #e5ebf6;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2964d7, #6ea8ff);
}

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

.progress-metrics small {
  display: block;
  color: #66758f;
}

.message-list {
  padding: 0 18px 6px;
  display: grid;
  gap: 18px;
}

.message-list article {
  padding-bottom: 14px;
  border-bottom: 1px solid #e6edf8;
}

.message-list article:last-child {
  border-bottom: 0;
}

.message-list strong {
  display: block;
  margin-bottom: 6px;
}

.side-card {
  overflow: hidden;
}

.weather-stack,
.notam-list,
.fatigue-card,
.roster-grid {
  padding: 18px;
}

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

.weather-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid #e7edf8;
}

.weather-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.weather-row span,
.notam-list article span {
  display: block;
  margin-top: 4px;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.9rem;
}

.section-label {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.section-label em {
  font-style: normal;
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #ffd256;
  color: #614300;
  font-size: 0.82rem;
  font-weight: 700;
}

.notam-list article {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  border-top: 1px solid #e7edf8;
}

.notam-list article strong {
  font-size: 0.96rem;
}

.fatigue-layout {
  display: grid;
  grid-template-columns: 174px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.ring-meter {
  width: 170px;
  height: 170px;
  border-radius: 50%;
  background:
    conic-gradient(#17a33e 0 245deg, #dfe7f5 245deg 360deg);
  display: grid;
  place-items: center;
}

.training-ring-meter {
  background:
    conic-gradient(#326ee8 0 220deg, #dfe7f5 220deg 360deg);
}

.ring-inner {
  width: 126px;
  height: 126px;
  border-radius: 50%;
  background: white;
  display: grid;
  place-items: center;
  text-align: center;
}

.ring-inner strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 2.4rem;
  color: #18335f;
}

.ring-inner span {
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.76rem;
  color: var(--muted);
}

.fatigue-stats {
  display: grid;
  gap: 12px;
}

.legal-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  padding: 0 18px 18px;
}

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

.roster-grid small {
  display: block;
  margin-top: 4px;
  color: #6d7b94;
}

.job-market-toolbar,
.market-grid,
.market-apply-bar,
.market-listings-toolbar,
.pilot-status-band,
.job-market-compact-note,
.credential-pill-list {
  padding: 0 18px 18px;
}

.market-filter-form,
.market-apply-bar {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(180px, 0.55fr) minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
}

.job-market-layout {
  grid-template-columns: minmax(0, 1fr);
}

.job-market-hero .card-header {
  align-items: start;
}

.job-market-intro {
  margin: 0;
  padding: 0 18px 16px;
  color: #61718d;
  line-height: 1.6;
}

.pilot-status-band {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.pilot-status-item {
  padding: 14px 15px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fbfdff, #f4f8ff);
}

.pilot-status-item span {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.73rem;
  font-weight: 700;
  color: var(--muted);
}

.pilot-status-item strong {
  display: block;
  margin-top: 8px;
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.16rem;
  line-height: 1.2;
}

.pilot-status-employer {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
  min-height: 48px;
}

.pilot-status-employer strong {
  margin-top: 0;
}

.pilot-status-employer__logo {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  border-radius: 14px;
  border: 1px solid #d6e1f4;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(23, 49, 94, 0.08);
}

.job-market-compact-note {
  display: grid;
  gap: 6px;
}

.job-market-compact-note strong {
  color: #17315e;
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.job-market-compact-note span {
  color: #61718d;
  line-height: 1.6;
}

.market-filter-form-tight {
  grid-template-columns: minmax(300px, 1.2fr) minmax(170px, 0.45fr);
}

.market-filter-summary {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
}

.market-filter-summary.compact {
  margin: 0 22px 22px;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}

.market-filter-summary-copy {
  display: grid;
  gap: 4px;
}

.market-filter-summary-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
}

.market-filter-summary span,
.market-empty-icon,
.market-hub-chip,
.market-headline-row .message-category {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.74rem;
  font-weight: 700;
}

.market-filter-summary strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.18rem;
  color: #17315e;
}

.market-filter-summary small {
  color: #61718d;
  line-height: 1.5;
}

.market-apply-bar {
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
  padding-top: 18px;
}

.market-input-group {
  display: grid;
  gap: 8px;
}

.market-input-group label {
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.market-input-group input,
.market-input-group select {
  width: 100%;
  border-radius: 16px;
  border: 1px solid #d7e2f2;
  padding: 14px 16px;
  font: inherit;
  color: #18335f;
  background: rgba(252, 253, 255, 0.98);
}

.market-input-group input:focus,
.market-input-group select:focus {
  outline: none;
  border-color: #7aa7ef;
  box-shadow: 0 0 0 3px rgba(66, 123, 233, 0.14);
}

.market-filter-actions {
  display: flex;
  justify-content: flex-end;
}

.market-action-stack {
  display: grid;
  gap: 10px;
  justify-items: end;
}

.market-action-button,
.market-card-button {
  min-width: 168px;
}

.market-action-button {
  border-color: #2e73db;
  background: linear-gradient(180deg, #3f8bff, #2666d3);
  color: #ffffff;
  box-shadow: 0 14px 28px rgba(39, 102, 211, 0.24);
}

.market-action-button:hover,
.market-action-button:focus-visible {
  border-color: #2059bf;
  background: linear-gradient(180deg, #4a95ff, #215fc9);
  box-shadow: 0 18px 32px rgba(39, 102, 211, 0.3);
}

.market-secondary-button,
.outline-button.market-secondary-button {
  border-color: #c98a8a;
  background: linear-gradient(180deg, #fff8f8, #f8e8e8);
  color: #964141;
  box-shadow: 0 10px 20px rgba(146, 67, 67, 0.12);
}

.market-secondary-button:hover,
.market-secondary-button:focus-visible,
.outline-button.market-secondary-button:hover,
.outline-button.market-secondary-button:focus-visible {
  border-color: #b46c6c;
  background: linear-gradient(180deg, #fff1f1, #f2dede);
  color: #873636;
  box-shadow: 0 14px 24px rgba(146, 67, 67, 0.18);
}

.text-action-link {
  color: var(--blue-500);
  font-weight: 700;
  text-decoration: none;
}

.text-action-link:hover {
  text-decoration: underline;
}

.market-apply-form {
  display: grid;
}

.market-card-action-form {
  margin: 0;
}

.market-listings-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 0.95fr) minmax(0, 1.45fr);
  gap: 14px;
  align-items: end;
}

.market-input-group.compact {
  gap: 6px;
}

.market-apply-hint {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
}

.market-apply-hint.compact {
  padding-top: 12px;
  padding-bottom: 12px;
}

.market-selected-rating {
  display: grid;
  gap: 3px;
  justify-items: end;
  text-align: right;
}

.market-selected-rating span {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
}

.market-selected-rating strong {
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.08rem;
}

.market-apply-hint strong,
.market-card-note span,
.empty-state-note {
  color: #28466f;
}

.market-apply-hint span,
.market-card-note span,
.credential-pill span,
.empty-state-note {
  line-height: 1.6;
}

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

.market-empty-state {
  display: grid;
  gap: 6px;
}

.market-empty-state strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.42rem;
  color: #17315e;
}

.market-empty-icon {
  color: #4b78d0;
}

.airline-market-card {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  display: grid;
  gap: 14px;
  box-shadow: 0 18px 40px rgba(30, 57, 111, 0.08);
}

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

.airline-market-head h3 {
  margin: 8px 0 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.52rem;
  color: #17315e;
}

.market-headline-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.market-code-pill {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(38, 117, 234, 0.12);
  color: #2157b4;
}

.market-hub-chip {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(15, 28, 53, 0.06);
  color: #425a82;
}

.market-subtitle {
  margin: 10px 0 0;
  color: #60708b;
  line-height: 1.55;
}

.market-status-wrap {
  display: flex;
  justify-content: flex-end;
}

.market-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.market-pill {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(38, 117, 234, 0.11);
  color: #2157b4;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.airline-market-sections {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.market-section-block {
  padding: 14px 14px 12px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(238, 245, 255, 0.94));
  border: 1px solid #dce6f5;
}

.market-section-block h4 {
  margin: 0 0 12px;
  color: #17315e;
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.market-section-list {
  display: grid;
  gap: 10px;
}

.market-section-row {
  display: grid;
  gap: 4px;
}

.market-section-row span {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.72rem;
  color: var(--muted);
}

.market-section-row strong {
  color: #17315e;
  font-size: 0.98rem;
  line-height: 1.45;
}

.market-metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.market-metric-card {
  padding: 14px 14px 12px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(236, 244, 255, 0.92));
  border: 1px solid #dce6f5;
}

.market-metric-grid span {
  display: block;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.74rem;
  color: var(--muted);
}

.market-metric-grid strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.32rem;
  color: #17315e;
}

.market-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding-top: 2px;
}

.market-card-note {
  max-width: 72%;
}

.market-status-open {
  background: linear-gradient(180deg, #ecfbf1, #dff7e7);
  color: #178a41;
}

.market-status-blocked {
  background: linear-gradient(180deg, #fff7e8, #ffefd0);
  color: #a86b09;
}

.market-card-button-current {
  border-color: #7ba2df;
  background: linear-gradient(180deg, #dceaff, #c8dcff);
  color: #173f88;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.market-current-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 168px;
  padding: 12px 18px;
  border-radius: 12px;
  background: linear-gradient(180deg, #dceaff, #c8dcff);
  border: 1px solid #7ba2df;
  color: #173f88;
  font-weight: 700;
}

.contract-break-card {
  border-color: #f1d9a6;
  background: linear-gradient(180deg, #fffdf7, #fff8e8);
}

.contract-break-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 0 18px 18px;
}

.contract-break-hero {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 248, 228, 0.96));
  border-color: #efd59f;
}

.contract-break-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 18px 18px;
}

.contract-break-form {
  margin: 0;
}

.credential-pill-list {
  display: grid;
  gap: 12px;
}

.credential-pill {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
}

.credential-pill strong {
  display: block;
  margin-bottom: 4px;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.2rem;
  color: #17315e;
}

.job-market-side-panel {
  display: grid;
  gap: 10px;
}

.market-side-row {
  padding: 12px 0;
}

.market-side-row + .market-side-row {
  border-top: 1px solid var(--line);
}

.side-panel-actions {
  padding-top: 14px;
  display: flex;
  justify-content: flex-start;
}

.job-market-guide-card {
  overflow: hidden;
}

.job-market-guide-header {
  padding: 0 18px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.job-market-guide-header h2 {
  margin: 0;
}

.job-market-guide-header p {
  margin: 8px 0 0;
  color: #61718d;
  line-height: 1.6;
}

.job-market-steps {
  padding: 0 18px 18px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.job-market-step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f6f9ff);
}

.job-market-step__number {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid #c9d7ef;
  background: #ffffff;
  color: #6a7b96;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
}

.job-market-step strong {
  display: block;
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.28rem;
}

.job-market-step small {
  display: block;
  margin-top: 4px;
  color: #61718d;
  line-height: 1.45;
}

.job-market-step.is-active {
  border-color: #b8cff7;
  box-shadow: 0 16px 32px rgba(40, 80, 155, 0.08);
}

.job-market-step.is-active .job-market-step__number,
.job-market-step.is-complete .job-market-step__number {
  border-color: #2f75ea;
  background: linear-gradient(180deg, #3e8aff, #2564d2);
  color: #ffffff;
  box-shadow: 0 10px 20px rgba(47, 117, 234, 0.22);
}

.job-market-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 18px;
}

.job-market-browser-card,
.job-market-detail-card {
  overflow: hidden;
}

.job-market-browser-card .card-header,
.job-market-detail-card .card-header {
  padding: 18px 22px 12px;
}

.job-market-browser-toolbar {
  display: grid;
  gap: 14px;
}

.job-market-browser-toolbar .market-filter-form-tight {
  margin: 0;
  padding: 0 22px;
}

.job-market-airline-list {
  padding: 0 22px 22px;
  display: grid;
  gap: 16px;
}

.job-market-airline-option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  color: inherit;
  text-decoration: none;
  box-shadow: 0 18px 38px rgba(30, 57, 111, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.job-market-airline-option:hover {
  transform: translateY(-1px);
  border-color: #bfd3f5;
  box-shadow: 0 22px 42px rgba(30, 57, 111, 0.12);
}

.job-market-airline-option.is-selected {
  border-color: #3f80f0;
  box-shadow: 0 0 0 2px rgba(63, 128, 240, 0.14), 0 20px 42px rgba(30, 57, 111, 0.14);
}

.job-market-airline-option--empty {
  grid-template-columns: 1fr;
}

.job-market-airline-option__pick {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 6px;
}

.job-market-airline-option__radio {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid #b8c6df;
  background: #ffffff;
  position: relative;
}

.job-market-airline-option.is-selected .job-market-airline-option__radio {
  border-color: #2f75ea;
}

.job-market-airline-option.is-selected .job-market-airline-option__radio::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  background: linear-gradient(180deg, #3e8aff, #2564d2);
}

.job-market-airline-option__content {
  display: grid;
  gap: 14px;
}

.job-market-airline-option__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.job-market-airline-option__head h3 {
  margin: 8px 0 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.46rem;
  color: #17315e;
}

.job-market-airline-option__metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(239, 245, 255, 0.94));
}

.job-market-airline-option__metrics span,
.job-market-detail-metrics span,
.job-market-review-note span,
.job-market-detail-step__eyebrow {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
}

.job-market-airline-option__metrics strong,
.job-market-detail-metrics strong {
  display: block;
  margin-top: 6px;
  color: #17315e;
  font-size: 1rem;
  line-height: 1.35;
}

.job-market-browser-foot {
  padding: 0 22px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.job-market-browser-note {
  display: grid;
  gap: 4px;
}

.job-market-browser-note strong {
  color: #28466f;
}

.job-market-browser-note span {
  color: #61718d;
  line-height: 1.6;
}

.job-market-detail-empty {
  padding: 0 22px 22px;
  display: grid;
  gap: 8px;
}

.job-market-detail-empty strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.42rem;
  color: #17315e;
}

.job-market-detail-empty span {
  color: #61718d;
  line-height: 1.65;
}

.job-market-detail-hero {
  margin: 0 22px 18px;
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.job-market-detail-hero__main {
  display: grid;
  gap: 8px;
}

.job-market-detail-hero__main strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.7rem;
  color: #17315e;
}

.job-market-detail-hero__main span {
  color: #60708b;
  line-height: 1.55;
}

.job-market-detail-form {
  display: grid;
  gap: 16px;
  padding: 0 22px 22px;
}

.job-market-detail-step {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  display: grid;
  gap: 14px;
}

.job-market-detail-step--rating {
  border-color: #bad0f5;
  background: linear-gradient(180deg, #ffffff, #f3f8ff);
  box-shadow: 0 18px 36px rgba(33, 77, 155, 0.1);
}

.job-market-detail-step__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.job-market-detail-step__head strong {
  display: block;
  margin-top: 4px;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.36rem;
  color: #17315e;
}

.job-market-detail-step__head small {
  color: #61718d;
  font-weight: 700;
}

.job-market-detail-hint--rating {
  border-color: #c4d7f7;
  background: linear-gradient(180deg, #fdfefe, #edf5ff);
}

.job-market-detail-hint--hub {
  border-color: #abd3c6;
  background: linear-gradient(180deg, #fbfffe, #edf8f4);
}

.job-market-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.job-market-mode-option {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #ffffff, #f6f9ff);
  cursor: pointer;
}

.job-market-mode-option input {
  margin: 0 0 4px;
  accent-color: #326ee8;
}

.job-market-mode-option span {
  color: #17315e;
  font-weight: 700;
}

.job-market-mode-option small {
  color: #61718d;
  line-height: 1.5;
}

.job-market-mode-option.is-selected {
  border-color: #6b9cf0;
  box-shadow: 0 0 0 2px rgba(63, 128, 240, 0.12);
}

.job-market-detail-hint {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
}

.job-market-detail-hint strong {
  color: #28466f;
}

.job-market-detail-hint span {
  color: #61718d;
  line-height: 1.6;
}

.job-market-rating-auto {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #bfd4f8;
  background: linear-gradient(180deg, #ffffff, #eef5ff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.job-market-rating-auto__label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
}

.job-market-rating-auto strong {
  color: #17315e;
  font-size: 1.06rem;
  line-height: 1.45;
}

.job-market-rating-auto small {
  color: #61718d;
  line-height: 1.6;
}

.job-market-rating-auto__warning {
  color: #b43232;
  font-weight: 700;
}

.job-market-rating-field {
  padding: 16px 18px 18px;
  border-radius: 18px;
  border: 1px solid #bfd4f8;
  background: linear-gradient(180deg, #ffffff, #eef5ff);
  box-shadow: 0 14px 28px rgba(44, 91, 176, 0.08);
}

.job-market-hub-field {
  padding: 16px 18px 18px;
  border-radius: 18px;
  border: 1px solid #b9ded0;
  background: linear-gradient(180deg, #ffffff, #eef8f4);
  box-shadow: 0 14px 28px rgba(28, 104, 83, 0.08);
}

.job-market-hub-field label {
  color: #19735c;
}

.job-market-hub-field select {
  border-color: #8fc8b4;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(28, 104, 83, 0.08);
}

.job-market-hub-field small {
  color: #61718d;
  line-height: 1.55;
}

.job-market-hub-readonly {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #c9dcf7;
  background: linear-gradient(180deg, #ffffff, #f3f8ff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.job-market-hub-readonly__label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
}

.job-market-hub-readonly strong {
  color: #17315e;
  font-size: 1.06rem;
  line-height: 1.45;
}

.job-market-hub-readonly small {
  color: #61718d;
  line-height: 1.55;
}

.job-market-rating-field label {
  color: #2d5fb8;
}

.job-market-rating-field select {
  border-color: #8eb4f5;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(60, 113, 207, 0.08);
}

.job-market-rating-field small {
  color: #61718d;
  line-height: 1.55;
}

.job-market-detail-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
}

.job-market-detail-step--review {
  gap: 16px;
}

.job-market-review-note {
  display: grid;
  gap: 6px;
}

.job-market-review-note strong {
  color: #17315e;
  font-size: 1rem;
  line-height: 1.55;
}

.job-market-review-note span {
  text-transform: none;
  letter-spacing: normal;
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1.65;
}

.job-market-apply-submit {
  width: 100%;
  min-height: 58px;
  margin-top: 0;
  font-size: 1rem;
  font-weight: 800;
  border-color: #218a53;
  background: linear-gradient(180deg, #31c56f, #1f9e56);
  color: #ffffff;
  box-shadow: 0 18px 32px rgba(31, 136, 73, 0.26);
}

.job-market-apply-submit:hover,
.job-market-apply-submit:focus-visible {
  border-color: #197944;
  background: linear-gradient(180deg, #39d777, #1b924f);
  color: #ffffff;
  box-shadow: 0 22px 36px rgba(31, 136, 73, 0.32);
}

@media (max-width: 1280px) {
  .pilot-status-band {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .market-listings-toolbar,
  .market-filter-form-tight {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .market-filter-actions {
    justify-content: flex-start;
  }

  .market-selected-rating {
    justify-items: start;
    text-align: left;
  }

  .market-filter-summary.compact {
    grid-template-columns: 1fr;
  }

  .market-filter-summary-actions {
    justify-content: flex-start;
  }

  .job-market-steps,
  .job-market-mode-grid,
  .job-market-detail-metrics,
  .job-market-airline-option__metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .job-market-workspace {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  .pilot-status-band,
  .airline-market-sections,
  .market-listings-toolbar,
  .market-filter-form-tight {
    grid-template-columns: 1fr;
  }

  .market-selected-rating {
    margin: 0 22px 0;
  }

  .market-card-note {
    max-width: none;
  }

  .job-market-guide-header,
  .job-market-browser-foot,
  .job-market-detail-hero,
  .job-market-detail-step__head,
  .job-market-airline-option__head {
    grid-template-columns: 1fr;
    display: grid;
  }

  .job-market-steps,
  .job-market-mode-grid,
  .job-market-detail-metrics,
  .job-market-airline-option__metrics {
    grid-template-columns: 1fr;
  }

  .job-market-airline-option {
    grid-template-columns: 1fr;
  }

  .job-market-airline-option__pick {
    justify-content: flex-start;
    padding-top: 0;
  }

  .job-market-browser-card .card-header,
  .job-market-detail-card .card-header {
    padding: 18px 18px 12px;
  }

  .job-market-browser-toolbar .market-filter-form-tight,
  .job-market-airline-list,
  .job-market-browser-foot,
  .job-market-detail-empty,
  .job-market-detail-form {
    padding-left: 18px;
    padding-right: 18px;
  }

  .market-filter-summary.compact,
  .job-market-detail-hero {
    margin-left: 18px;
    margin-right: 18px;
  }
}

.stacked-action-form {
  width: 100%;
}

.stacked-option-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  color: #5d7191;
  font-size: 0.88rem;
  line-height: 1.4;
}

.stacked-option-toggle input {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: #326ee8;
}

.stacked-action-form .primary-button {
  width: 100%;
  margin-top: 0;
}

.jumpseat-panel {
  display: grid;
  gap: 16px;
}

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

.jumpseat-copy {
  margin: 0;
  color: #5f7190;
  line-height: 1.6;
}

.jumpseat-copy strong {
  color: #17315e;
}

.jumpseat-form {
  display: grid;
  gap: 14px;
}

.jumpseat-divider {
  height: 1px;
  background: linear-gradient(90deg, rgba(152, 174, 214, 0.08), rgba(152, 174, 214, 0.5), rgba(152, 174, 214, 0.08));
}

.jumpseat-transfer-block {
  display: grid;
  gap: 14px;
}

.jumpseat-stat-grid--transfer {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.jumpseat-hub-select {
  width: 100%;
  min-width: 0;
}

.jumpseat-helper-text {
  display: block;
  margin-top: 8px;
  color: #607392;
  line-height: 1.55;
}

.jumpseat-transfer-empty {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #dce5f4;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
}

.jumpseat-transfer-empty strong {
  color: #17315e;
}

.jumpseat-transfer-empty span {
  color: #607392;
  line-height: 1.55;
}

.jumpseat-input-shell {
  display: grid;
}

.jumpseat-submit-button {
  width: 100%;
  margin-top: 0;
}

.schedule-generate-form {
  display: flex;
  align-items: flex-end;
  gap: 14px;
  flex-wrap: wrap;
  padding: 6px 0;
}

.schedule-generate-input-shell {
  display: block;
  padding: 10px 14px 12px;
  border-radius: 18px;
  border: 1px solid rgba(26, 63, 123, 0.12);
  background: linear-gradient(180deg, #ffffff, #f7fbff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.schedule-generate-select {
  min-width: 156px;
  width: auto;
  border-radius: 14px;
  padding: 12px 42px 12px 16px;
  font-weight: 700;
  color: #183764;
}

.schedule-generate-button {
  width: auto;
  min-width: 190px;
  min-height: 54px;
  padding: 0 24px;
  border-radius: 16px;
  box-shadow: 0 14px 30px rgba(33, 96, 202, 0.24);
  margin-top: 0;
}

.schedule-generate-form .inline-action-label {
  margin: 0 0 6px;
  white-space: nowrap;
  color: #526784;
}

.options-form-grid {
  padding: 0 18px 18px;
  display: grid;
  gap: 14px;
}

.option-toggle-card {
  display: block;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #dce6f5;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  box-shadow: 0 12px 28px rgba(30, 57, 111, 0.06);
}

.option-toggle-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.option-toggle-main strong {
  display: block;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.34rem;
  color: #17315e;
  margin-bottom: 6px;
}

.option-toggle-main span {
  display: block;
  line-height: 1.65;
  color: #61718d;
}

.option-toggle-switch {
  display: grid;
  justify-items: center;
  gap: 8px;
  min-width: 64px;
}

.option-toggle-switch input[type="checkbox"] {
  width: 22px;
  height: 22px;
  accent-color: #2e6fe4;
}

.option-toggle-switch em {
  font-style: normal;
  font-weight: 700;
  color: #17315e;
}

.options-form-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 14px;
}

.options-save-button {
  min-width: 220px;
  margin-top: 0;
  padding: 16px 22px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at top, rgba(142, 201, 255, 0.34), transparent 52%),
    linear-gradient(180deg, #3186f8 0%, #195bc6 100%);
  box-shadow:
    0 18px 34px rgba(23, 85, 191, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.options-save-button:hover {
  transform: translateY(-1px);
  filter: saturate(1.04);
  box-shadow:
    0 22px 38px rgba(23, 85, 191, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.options-save-button:focus-visible {
  outline: 3px solid rgba(63, 136, 255, 0.26);
  outline-offset: 3px;
}

.training-submit-button {
  min-width: 240px;
  margin-top: 0;
  font-size: 1rem;
  font-weight: 700;
  box-shadow: 0 16px 32px rgba(26, 91, 195, 0.22);
}

.training-submit-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(26, 91, 195, 0.28);
}

@media (max-width: 2100px) {
  .app-shell {
    grid-template-columns: 236px minmax(0, 1fr);
  }

  .sidebar {
    padding: 24px 16px 20px;
  }

  .sidebar-brand {
    gap: 12px;
    margin-bottom: 24px;
  }

  .brand-mark {
    width: 58px;
    min-width: 58px;
    height: 58px;
    padding: 12px 11px;
  }

  .nav-item {
    padding: 11px 12px;
    font-size: 0.94rem;
  }

  .main-panel {
    padding: 18px 18px 24px;
  }

  .topbar {
    padding: 16px 18px;
    gap: 16px;
  }

  .topbar-left,
  .topbar-right {
    gap: 16px;
  }

  .top-links {
    gap: 14px;
  }

  .top-link-group {
    gap: 12px;
    padding-right: 0;
    border-right: none;
  }

  .top-link {
    font-size: 0.94rem;
  }

  .airline-chip {
    display: none;
  }

  .hero-card {
    grid-template-columns: 108px minmax(0, 1fr);
    gap: 14px;
  }

  .profile-avatar.large {
    width: 90px;
    height: 90px;
  }

  .rank-id-card {
    width: 92px;
    min-height: 114px;
  }

  .hero-content h1 {
    font-size: 1.82rem;
  }

  .metric-block {
    padding: 14px 16px;
  }

  .metric-block strong {
    font-size: 1.42rem;
  }

  .route-points strong {
    font-size: 2.5rem;
  }

  .flight-number {
    font-size: 1.9rem;
  }

  .hero-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .metric-block:nth-child(4) {
    border-left: 0;
  }

  .assignment-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .schedule-layout,
  .bidding-layout,
  .profile-layout {
    grid-template-columns: 1fr;
  }

  .route-panel {
    border-left: 0;
    border-right: 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 18px 0;
  }

  .flight-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1720px) {
  .content-grid,
  .fatigue-layout {
    grid-template-columns: 1fr;
  }

  .side-panel-card {
    position: static;
  }
}

@media (max-width: 1400px) {
  .hero-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .metric-block:nth-child(4) {
    border-left: 0;
  }

  .assignment-grid,
  .content-grid,
  .fatigue-layout {
    grid-template-columns: 1fr;
  }

  .route-panel {
    border-left: 0;
    border-right: 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 18px 0;
  }

  .weather-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1120px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .login-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    display: none;
  }

  .portal-topbar {
    padding: 18px;
    flex-direction: column;
    align-items: flex-start;
  }

  .dashboard-grid.two-up,
  .roster-grid,
  .hero-metrics,
  .summary-grid,
  .schedule-meta-grid,
  .jumpseat-stat-grid {
    grid-template-columns: 1fr;
  }

  .metric-block + .metric-block {
    border-left: 0;
    border-top: 1px solid var(--line);
  }

  .topbar {
    align-items: start;
    flex-direction: column;
  }

  .topbar-left,
  .topbar-right,
  .hero-header {
    width: 100%;
    flex-wrap: wrap;
  }

  .airline-chip,
  .airline-badge {
    max-width: 100%;
  }

  .airline-logo-card {
    max-width: 100%;
    min-width: 0;
  }

  .airline-style {
    min-height: auto;
  }

  .airline-hero,
  .airline-panel {
    padding: 30px 20px;
  }

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

  .market-filter-form,
  .market-apply-bar {
    grid-template-columns: 1fr;
  }

  .market-action-stack {
    justify-items: stretch;
  }

  .market-action-button,
  .market-card-button {
    width: 100%;
  }

  .roster-action-form {
    width: 100%;
    flex-wrap: wrap;
  }

  .market-card-foot {
    align-items: start;
    flex-direction: column;
  }

  .market-card-note {
    max-width: none;
  }

  .contract-break-grid {
    grid-template-columns: 1fr;
  }

  .contract-break-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .option-toggle-main {
    flex-direction: column;
  }

  .options-form-actions {
    justify-content: stretch;
  }

  .options-save-button {
    width: 100%;
  }

  .hero-aircraft {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    margin-top: 26px;
    height: 220px;
  }

  .hero-footer-line {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    margin-top: 20px;
  }

  .topbar-left,
  .topbar-right,
  .top-links {
    flex-wrap: wrap;
  }
}

@media (max-width: 720px) {
  .main-panel {
    padding: 12px;
  }

  .login-copy h1 {
    font-size: 2.8rem;
  }

  .airline-copy h1 {
    font-size: 3rem;
  }

  .airline-card {
    padding: 28px 20px 24px;
  }

  .form-split {
    grid-template-columns: 1fr;
  }

  .auth-switch {
    flex-direction: column;
    align-items: flex-start;
  }

  .portal-topbar-links {
    gap: 8px;
  }

  .portal-topbar-links a,
  .status-live {
    border-left: 0;
    padding: 0;
  }

  .topbar,
  .hero-card,
  .assignment-grid,
  .assignment-footer {
    padding-left: 14px;
    padding-right: 14px;
  }

  .hero-card {
    grid-template-columns: 1fr;
  }

  .hero-identity {
    justify-content: start;
  }

  .route-points {
    flex-direction: column;
    align-items: start;
  }

  .mini-weather-strip,
  .assignment-footer {
    flex-direction: column;
    align-items: start;
  }

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

.training-form {
  display: grid;
  gap: 22px;
}

.training-page {
  display: grid;
  gap: 18px;
  margin-top: 16px;
}

.training-command-card,
.training-enrollment-card,
.training-support-card,
.training-history-card,
.training-notes-card {
  background:
    radial-gradient(circle at top right, rgba(117, 172, 255, 0.08), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.training-command-card .card-header,
.training-enrollment-card .card-header,
.training-support-card .card-header,
.training-history-card .card-header,
.training-notes-card .card-header {
  padding: 18px 18px 14px;
}

.training-command-card__header,
.training-enrollment-card__header {
  align-items: center;
  flex-wrap: wrap;
}

.training-command-card .section-caption,
.training-enrollment-card .section-caption,
.training-support-card .section-caption,
.training-history-card .section-caption,
.training-notes-card .section-caption {
  color: #5f7290;
  font-size: 0.96rem;
  line-height: 1.45;
}

.training-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding: 0 18px 18px;
}

.training-metric-card {
  min-height: 118px;
  padding: 18px 20px;
  border-radius: 22px;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid rgba(23, 49, 94, 0.1);
  box-shadow: 0 10px 24px rgba(14, 29, 57, 0.06);
}

.training-metric-card__icon,
.training-summary-tile__icon,
.training-profile-card__icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #f3f7ff, #e7efff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.training-metric-card__icon svg,
.training-summary-tile__icon svg,
.training-profile-card__icon svg,
.training-mode-card__icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.training-metric-card__body {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.training-metric-card__body span {
  color: #5b6f8d;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.78rem;
  font-weight: 700;
}

.training-metric-card__body strong {
  color: #132c59;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.62rem;
  line-height: 1.02;
}

.training-metric-card__body small {
  color: #5f7290;
  font-size: 0.95rem;
}

.training-metric-card--success .training-metric-card__icon,
.training-summary-tile:nth-child(2) .training-summary-tile__icon {
  color: #0f9a53;
  background: linear-gradient(180deg, #eefbf3, #def5e6);
}

.training-metric-card--warning .training-metric-card__icon {
  color: #14a15d;
  background: linear-gradient(180deg, #eefbf3, #def5e6);
}

.training-metric-card--danger .training-metric-card__icon {
  color: #c2362b;
  background: linear-gradient(180deg, #fff3f2, #ffe4e1);
}

.training-metric-card--neutral .training-metric-card__icon,
.training-summary-tile:nth-child(1) .training-summary-tile__icon {
  color: #256de8;
}

.training-overview-grid .training-metric-card:nth-child(4) .training-metric-card__icon,
.training-summary-tile:nth-child(3) .training-summary-tile__icon,
.training-mode-card--company .training-mode-card__icon {
  color: #7d49d7;
  background: linear-gradient(180deg, #f7f1ff, #ece0ff);
}

.training-page .primary-column {
  gap: 18px;
}

.training-filter-form {
  align-items: end;
}

.training-filter-form--stacked {
  grid-template-columns: 1fr;
}

.training-filter-field {
  max-width: 380px;
}

.training-select {
  width: 100%;
  min-height: 54px;
  padding: 14px 18px;
  border-radius: 16px;
  border: 1px solid #d7e2f2;
  background: linear-gradient(180deg, #ffffff, #f5f8ff);
  color: #17315e;
  font: inherit;
  font-weight: 600;
  box-shadow: 0 12px 24px rgba(29, 56, 110, 0.06);
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #2b63c6 50%),
    linear-gradient(135deg, #2b63c6 50%, transparent 50%),
    linear-gradient(180deg, #ffffff, #f5f8ff);
  background-position:
    calc(100% - 22px) calc(50% - 3px),
    calc(100% - 16px) calc(50% - 3px),
    0 0;
  background-size: 6px 6px, 6px 6px, 100% 100%;
  background-repeat: no-repeat;
}

.training-select:focus {
  outline: none;
  border-color: #7aa7ef;
  box-shadow: 0 0 0 3px rgba(66, 123, 233, 0.16), 0 14px 28px rgba(29, 56, 110, 0.1);
}

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

.training-mode-card {
  display: grid;
  grid-template-columns: 28px 56px minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  border: 1px solid #dce6f5;
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  box-shadow: 0 12px 28px rgba(30, 57, 111, 0.06);
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.training-mode-card:hover {
  transform: translateY(-1px);
  border-color: #bfd2f3;
  box-shadow: 0 16px 34px rgba(30, 57, 111, 0.1);
}

.training-mode-card:has(input:checked) {
  border-color: rgba(37, 109, 232, 0.42);
  background:
    radial-gradient(circle at top left, rgba(93, 145, 243, 0.12), transparent 32%),
    linear-gradient(180deg, #ffffff, #f6faff);
  box-shadow: 0 18px 36px rgba(30, 57, 111, 0.12);
}

.training-mode-card--company:has(input:checked) {
  border-color: rgba(125, 73, 215, 0.38);
  background:
    radial-gradient(circle at top left, rgba(150, 111, 236, 0.12), transparent 32%),
    linear-gradient(180deg, #ffffff, #fbf8ff);
}

.training-mode-card input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: #2e6fe4;
  margin: 0;
  align-self: start;
  margin-top: 4px;
}

.training-mode-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #edf4ff, #e5eeff);
}

.training-mode-card--pilot .training-mode-card__icon {
  color: #256de8;
}

.training-mode-card__copy {
  display: grid;
  gap: 8px;
}

.training-mode-card strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.3rem;
  color: #17315e;
}

.training-mode-card span {
  color: #61718d;
  line-height: 1.55;
}

.training-profile-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.training-summary-tile {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  box-shadow: 0 10px 24px rgba(14, 29, 57, 0.06);
}

.training-summary-tile > div:last-child {
  min-width: 0;
}

.summary-tile.compact {
  min-height: auto;
  padding: 18px 20px;
}

.training-summary-tile span {
  font-size: 0.76rem;
  letter-spacing: 0.06em;
  color: #61718d;
}

.training-summary-tile strong {
  margin-top: 5px;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.42rem;
  color: #132c59;
}

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

.credential-list,
.side-stat-list {
  display: grid;
  gap: 14px;
}

.credential-row,
.side-stat-list > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid #e2eaf6;
}

.credential-row:last-child,
.side-stat-list > div:last-child {
  border-bottom: 0;
}

.credential-row strong,
.side-stat-list strong {
  color: #17315e;
  font-size: 1.15rem;
}

.credential-row span,
.side-stat-list span {
  color: #6d7d98;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
}

.training-profile-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.training-profile-card {
  display: grid;
  gap: 8px;
  padding: 18px;
  border: 1px solid #dce6f5;
  border-radius: 20px;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  box-shadow: 0 12px 28px rgba(30, 57, 111, 0.06);
}

.training-profile-card__icon {
  width: 42px;
  height: 42px;
  color: #256de8;
}

.training-profile-card strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.3rem;
  color: #17315e;
}

.training-profile-card span {
  color: #61718d;
}

.training-support-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
  gap: 18px;
}

.training-support-card .empty-state {
  padding: 0 18px 24px;
  align-items: flex-start;
  text-align: left;
}

.training-credential-list,
.training-notes-list {
  padding: 0 18px 18px;
}

.training-credential-row {
  padding: 16px 0;
}

.training-credential-row strong,
.training-notes-list strong {
  font-family: "Rajdhani", sans-serif;
}

.training-credential-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 82px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(41, 160, 99, 0.16);
  background: linear-gradient(180deg, #ebfaef, #def6e6);
  color: #149256;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.training-profile-list,
.training-history-card .table-shell {
  padding: 0 18px 18px;
}

.training-history-card .data-table th {
  background: transparent;
}

.training-history-card .data-table th,
.training-history-card .data-table td {
  padding-left: 14px;
  padding-right: 14px;
}

.training-history-empty {
  padding: 28px 18px 22px;
}

.training-form-actions {
  justify-content: flex-end;
  padding-top: 6px;
}

.training-submit-button {
  min-width: 220px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.training-submit-button__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.training-submit-button__icon svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.table-shell {
  overflow-x: auto;
}

@media (max-width: 1400px) {
  .training-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .training-support-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .training-overview-grid,
  .training-credential-list,
  .training-profile-list,
  .training-notes-list,
  .training-history-card .table-shell {
    padding-left: 14px;
    padding-right: 14px;
  }

  .training-overview-grid {
    padding-bottom: 14px;
  }

  .training-metric-card {
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 14px;
    min-height: 108px;
    padding: 16px 18px;
    border-radius: 18px;
  }

  .training-metric-card__icon,
  .training-summary-tile__icon,
  .training-mode-card__icon {
    width: 48px;
    height: 48px;
  }

  .training-mode-card {
    grid-template-columns: 24px 48px minmax(0, 1fr);
    gap: 14px;
    padding: 16px 18px;
  }

  .training-form-actions {
    justify-content: stretch;
  }

  .training-submit-button {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 1280px) {
  .portal-login {
    grid-template-columns: 1fr;
  }

  .portal-login__visual {
    min-height: 62vh;
  }

  .portal-login__panel {
    padding-top: 0;
  }
}

@media (max-width: 780px) {
  .portal-login__visual {
    padding: 28px 20px 20px;
    min-height: 56vh;
  }

  .portal-login__panel {
    padding: 18px;
  }

  .portal-login__card {
    padding: 28px 20px 24px;
  }

  .portal-login--register {
    grid-template-columns: 1fr;
  }

  .portal-login__grid-2 {
    grid-template-columns: 1fr;
  }

  .portal-login__status-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .portal-login__status-row article:nth-child(2) {
    border-right: 0;
  }

  .portal-login__status-row article:nth-child(-n + 2) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .portal-login__logo--full {
    width: min(100%, 290px);
  }
}

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

.data-table thead th {
  text-align: left;
  padding: 0 0 12px;
  color: #6c7c96;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 1px solid #e2eaf6;
}

.data-table tbody td {
  padding: 14px 0;
  color: #17315e;
  border-bottom: 1px solid #edf2fb;
  vertical-align: top;
}

.data-table tbody tr:last-child td {
  border-bottom: 0;
}

.tone-success {
  color: #0f8d45 !important;
}

.tone-warning {
  color: #b06d00 !important;
}

.tone-danger {
  color: #b42318 !important;
}

.tone-neutral {
  color: #526783 !important;
}

.career-event-list {
  display: grid;
  gap: 14px;
  padding: 0 18px 18px;
}

.career-event-list.compact {
  padding-top: 2px;
}

.career-event-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  padding-bottom: 14px;
  border-bottom: 1px solid #e9effa;
}

.career-event-item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.career-event-copy {
  display: grid;
  gap: 4px;
}

.finance-page {
  display: grid;
  gap: 18px;
  margin-top: 16px;
}

.finance-overview-card {
  background:
    radial-gradient(circle at top right, rgba(119, 174, 255, 0.14), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.finance-overview-header {
  align-items: center;
}

.finance-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding: 0 18px 18px;
}

.finance-metric-card {
  min-height: 118px;
  padding: 18px 20px;
  border-radius: 22px;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid rgba(24, 50, 96, 0.1);
  box-shadow: 0 10px 24px rgba(16, 34, 64, 0.06);
}

.finance-metric-card__icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #f3f7ff, #e7efff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.finance-metric-card__icon svg,
.finance-ledger-type__icon svg,
.finance-events-card .section-title-icon svg,
.finance-support-card .section-title-icon svg,
.finance-overview-card .section-title-icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.finance-metric-card__body {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.finance-metric-card__body span,
.finance-snapshot-panel span,
.finance-progress-card__head span {
  color: #5b6f8d;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.78rem;
  font-weight: 700;
}

.finance-metric-card__body strong {
  color: #132c59;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.62rem;
  line-height: 1.02;
}

.finance-metric-card__body small {
  color: #5f7290;
  font-size: 0.95rem;
}

.finance-metric-card--success .finance-metric-card__icon {
  color: #0f9a53;
  background: linear-gradient(180deg, #eefbf3, #def5e6);
}

.finance-metric-card--danger .finance-metric-card__icon {
  color: #c2362b;
  background: linear-gradient(180deg, #fff3f2, #ffe4e1);
}

.finance-metric-card--neutral .finance-metric-card__icon {
  color: #256de8;
}

.finance-metric-card--warning .finance-metric-card__icon {
  color: #dd7a00;
  background: linear-gradient(180deg, #fff7ea, #ffedd0);
}

.finance-layout {
  grid-template-columns: minmax(0, 1.5fr) minmax(340px, 0.88fr);
  align-items: start;
}

.finance-sidebar {
  gap: 18px;
}

.finance-sidebar .side-panel-card,
.finance-support-card {
  position: static;
}

.finance-ledger-card__header {
  align-items: start;
}

.finance-ledger-card__note {
  color: #5a6f8f;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.finance-ledger-shell {
  padding: 0 18px;
}

.finance-ledger-table thead th:first-child,
.finance-ledger-table tbody td:first-child {
  min-width: 132px;
}

.finance-ledger-table thead th:nth-child(2),
.finance-ledger-table tbody td:nth-child(2) {
  min-width: 138px;
}

.finance-ledger-table thead th:nth-child(4),
.finance-ledger-table tbody td:nth-child(4),
.finance-ledger-table thead th:nth-child(5),
.finance-ledger-table tbody td:nth-child(5) {
  text-align: right;
}

.finance-ledger-table tbody td {
  padding: 18px 0;
}

.finance-ledger-row__posted {
  color: #526783;
  font-weight: 600;
}

.finance-ledger-row__summary {
  color: #17315e;
  font-weight: 600;
}

.finance-ledger-row__amount,
.finance-ledger-row__balance {
  font-weight: 700;
  white-space: nowrap;
}

.finance-ledger-type {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #1d3763;
  font-weight: 700;
}

.finance-ledger-type__icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.finance-ledger-type--success .finance-ledger-type__icon {
  color: #0f9a53;
  background: #e8f8ef;
}

.finance-ledger-type--danger .finance-ledger-type__icon {
  color: #c2362b;
  background: #fff0ee;
}

.finance-ledger-type--neutral .finance-ledger-type__icon {
  color: #256de8;
  background: #edf4ff;
}

.finance-ledger-type--warning .finance-ledger-type__icon {
  color: #d37b00;
  background: #fff4e1;
}

.finance-table-note {
  padding: 0 18px 18px;
  color: #667995;
}

.finance-support-card {
  padding-bottom: 18px;
}

.finance-side-stat-list {
  padding: 0 18px;
}

.finance-side-stat-list > div {
  padding: 12px 0;
}

.finance-snapshot-panel {
  margin: 6px 18px 0;
  padding: 16px 18px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
  border-radius: 18px;
  border: 1px solid #dbe6f7;
  background: linear-gradient(180deg, #fbfdff, #f4f8ff);
}

.finance-snapshot-panel strong {
  display: block;
  margin-top: 8px;
  color: #17315e;
  font-size: 1.24rem;
}

.finance-progress-card {
  margin: 6px 18px 0;
  padding: 16px 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, #fbfdff, #f5f9ff);
  border: 1px solid #dbe6f7;
}

.finance-progress-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.finance-progress-card__head strong {
  color: #17315e;
  font-size: 1.05rem;
}

.finance-progress-track {
  height: 12px;
  border-radius: 999px;
  background: #dbe4f2;
  overflow: hidden;
}

.finance-progress-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #256de8, #4d8dff);
  box-shadow: 0 8px 18px rgba(37, 109, 232, 0.26);
}

.finance-progress-card p {
  margin: 12px 0 0;
  color: #5e7290;
  line-height: 1.55;
}

.finance-events-card {
  background:
    radial-gradient(circle at top right, rgba(119, 174, 255, 0.08), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.finance-events-list {
  padding-top: 0;
}

@media (max-width: 1400px) {
  .finance-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .finance-overview-grid,
  .finance-snapshot-panel {
    grid-template-columns: 1fr;
  }

  .finance-metric-card {
    grid-template-columns: 52px minmax(0, 1fr);
    min-height: 104px;
  }
}

.logbook-page {
  display: grid;
  gap: 18px;
  margin-top: 16px;
}

.logbook-overview-card,
.logbook-table-card,
.logbook-support-card,
.logbook-events-card {
  background:
    radial-gradient(circle at top right, rgba(119, 174, 255, 0.1), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.logbook-overview-header {
  align-items: center;
  flex-wrap: wrap;
}

.logbook-overview-card .card-header,
.logbook-table-card .card-header,
.logbook-support-card .card-header,
.logbook-events-card .card-header {
  padding: 18px 18px 14px;
}

.logbook-overview-card .section-caption,
.logbook-table-card .section-caption,
.logbook-support-card .section-caption,
.logbook-events-card .section-caption {
  color: #5f7290;
  font-size: 0.96rem;
  line-height: 1.45;
}

.logbook-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding: 0 18px 18px;
}

.logbook-metric-card {
  min-height: 118px;
  padding: 18px 20px;
  border-radius: 22px;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid rgba(24, 50, 96, 0.1);
  box-shadow: 0 10px 24px rgba(16, 34, 64, 0.06);
}

.logbook-metric-card__icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #f3f7ff, #e7efff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.logbook-metric-card__icon svg,
.logbook-overview-card .section-title-icon svg,
.logbook-table-card .section-title-icon svg,
.logbook-support-card .section-title-icon svg,
.logbook-events-card .section-title-icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.logbook-metric-card__body {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.logbook-metric-card__body span,
.logbook-progress-card__head span {
  color: #5b6f8d;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.78rem;
  font-weight: 700;
}

.logbook-metric-card__body strong {
  color: #132c59;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.62rem;
  line-height: 1.02;
}

.logbook-metric-card__body small {
  color: #5f7290;
  font-size: 0.95rem;
}

.logbook-metric-card--success .logbook-metric-card__icon {
  color: #109457;
  background: linear-gradient(180deg, #eefbf3, #def5e6);
}

.logbook-metric-card--warning .logbook-metric-card__icon {
  color: #d17c10;
  background: linear-gradient(180deg, #fff8e9, #ffefca);
}

.logbook-metric-card--danger .logbook-metric-card__icon {
  color: #c2362b;
  background: linear-gradient(180deg, #fff3f2, #ffe4e1);
}

.logbook-metric-card--neutral .logbook-metric-card__icon {
  color: #256de8;
}

.logbook-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(320px, 0.85fr);
  gap: 18px;
  align-items: start;
}

.logbook-sidebar {
  display: grid;
  gap: 18px;
}

.logbook-support-card {
  padding-bottom: 18px;
}

.logbook-table-shell,
.logbook-events-list {
  padding: 0 18px 18px;
}

.logbook-table {
  min-width: 920px;
}

.logbook-table thead th {
  background: transparent;
}

.logbook-table thead th,
.logbook-table tbody td {
  padding-left: 14px;
  padding-right: 14px;
}

.logbook-table tbody td strong {
  display: block;
  color: #17315e;
  font-size: 1rem;
}

.logbook-table-meta,
.logbook-remarks {
  display: block;
  margin-top: 6px;
  color: #61718d;
  line-height: 1.5;
}

.logbook-route-code {
  letter-spacing: 0.02em;
}

.logbook-rating-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 74px;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.logbook-rating-pill--success {
  background: rgba(22, 181, 103, 0.14);
  color: #14804a;
}

.logbook-rating-pill--neutral {
  background: rgba(37, 109, 232, 0.12);
  color: #256de8;
}

.logbook-rating-pill--warning {
  background: rgba(245, 158, 11, 0.16);
  color: #b86a08;
}

.logbook-rating-pill--danger {
  background: rgba(239, 68, 68, 0.12);
  color: #bf3b3b;
}

.logbook-side-stat-list {
  padding: 0 18px;
}

.logbook-side-stat-list > div {
  padding: 12px 0;
}

.logbook-side-stat-list strong {
  font-family: "Rajdhani", sans-serif;
}

.logbook-progress-card {
  margin: 6px 18px 0;
  padding: 16px 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, #fbfdff, #f4f8ff);
  border: 1px solid #dbe6f7;
}

.logbook-progress-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.logbook-progress-card__head strong {
  color: #17315e;
  font-size: 1.05rem;
}

.logbook-progress-track {
  height: 12px;
  border-radius: 999px;
  background: #dbe4f2;
  overflow: hidden;
}

.logbook-progress-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #256de8, #4d8dff);
  box-shadow: 0 8px 18px rgba(37, 109, 232, 0.26);
}

.logbook-progress-card p {
  margin: 12px 0 0;
  color: #5e7290;
  line-height: 1.55;
}

.logbook-table-note {
  margin: 12px 18px 18px;
  color: #5e7290;
  line-height: 1.55;
}

.logbook-empty-state {
  margin: 0 18px 18px;
}

.logbook-events-list {
  padding-top: 0;
}

@media (max-width: 1400px) {
  .logbook-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .logbook-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .logbook-overview-grid {
    grid-template-columns: 1fr;
  }

  .logbook-metric-card {
    grid-template-columns: 52px minmax(0, 1fr);
    min-height: 104px;
  }
}

@media (max-width: 720px) {
  .logbook-overview-grid,
  .logbook-table-shell,
  .logbook-events-list {
    padding-left: 14px;
    padding-right: 14px;
  }

  .logbook-overview-grid {
    padding-bottom: 14px;
  }

  .logbook-metric-card {
    padding: 16px 18px;
    border-radius: 18px;
  }
}

.career-event-copy strong {
  color: #17315e;
}

.career-event-copy span {
  color: #60708b;
  line-height: 1.55;
}

.career-event-item time {
  color: #6d7d98;
  font-size: 0.82rem;
  white-space: nowrap;
}

.side-panel-card {
  position: sticky;
  top: 18px;
}

.bidding-layout {
  grid-template-columns: minmax(0, 1.7fr) minmax(340px, 0.85fr);
}

.bidding-command-card .card-header {
  align-items: center;
}

.bidding-submit-button {
  margin-top: 0;
  min-width: 150px;
}

.bidding-summary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.bidding-filter-form {
  grid-template-columns: minmax(150px, 0.5fr) minmax(180px, 0.55fr) minmax(240px, 1fr) auto;
}

.bidding-table-shell {
  padding: 0 18px 18px;
}

.bidding-table {
  min-width: 760px;
}

.bidding-table td span {
  display: block;
  margin-top: 4px;
  color: #6b7b96;
  font-size: 0.86rem;
}

.bidding-status-pill {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 76px;
  margin-top: 0 !important;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.76rem !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.bidding-row-form {
  display: flex;
  justify-content: flex-end;
}

.bid-stack-list {
  display: grid;
  gap: 10px;
  padding: 0 18px 18px;
}

.bid-stack-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  border: 1px solid #dce6f5;
  border-radius: 16px;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
}

.bid-stack-rank {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.18rem;
  font-weight: 700;
  color: #17315e;
}

.bid-stack-item strong,
.bid-stack-item span {
  display: block;
}

.bid-stack-item strong {
  color: #1d57bd;
}

.bid-stack-item span {
  margin-top: 3px;
  color: #60708b;
  font-size: 0.9rem;
}

.bid-stack-status {
  padding: 6px 9px;
  border-radius: 999px;
  background: #eef3fb;
  color: #526783;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

.bid-stack-status.awarded {
  background: #e3f8ec;
  color: #137d3b;
}

.bid-stack-status.not_awarded {
  background: #fff2dc;
  color: #a16304;
}

.bid-remove-button,
.text-button {
  border: 0;
  background: transparent;
  cursor: pointer;
  color: #63728c;
  font-weight: 700;
}

.bid-remove-button {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  font-size: 1rem;
}

.bid-remove-button:hover,
.text-button:hover {
  color: #1d57bd;
}

.bidding-side-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 18px 18px;
  color: #60708b;
  font-weight: 600;
}

.profile-layout {
  grid-template-columns: minmax(0, 1.4fr) minmax(340px, 0.75fr);
}

.profile-identity-card {
  padding: 22px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 20px;
}

.profile-identity-card h1 {
  margin: 0 0 10px;
  font-size: 2rem;
  color: #1b2f60;
}

.profile-meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.profile-meta-line span {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: #eef5ff;
  color: #28466f;
  font-weight: 700;
  font-size: 0.86rem;
}

.profile-form,
.license-panel {
  padding: 0 18px 18px;
  display: grid;
  gap: 16px;
}

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

.profile-form-actions {
  display: flex;
  justify-content: flex-end;
}

.profile-form-actions--inline {
  padding: 0;
}

.profile-branding-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 0 18px 18px;
}

.profile-branding-card {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid #d9e5f6;
  background: linear-gradient(180deg, #fbfdff, #f6f9ff);
  grid-template-rows: minmax(88px, auto) auto auto;
}

.profile-branding-preview {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  min-height: 88px;
}

.profile-branding-preview__badge {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(135deg, #d8e8ff, #eef4ff);
  border: 1px solid #c5d8f7;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.profile-branding-preview__badge img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.profile-branding-preview__badge--empty {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #2b66de;
  letter-spacing: 0.06em;
}

.profile-branding-preview strong {
  display: block;
  margin-bottom: 4px;
  color: #17315e;
  font-size: 1rem;
}

.profile-branding-preview span {
  color: #6d7f9a;
  line-height: 1.5;
}

.profile-branding-form {
  gap: 12px;
}

.profile-branding-form__row {
  display: grid;
  gap: 12px;
  justify-items: start;
}

.profile-branding-form__row input[type="file"] {
  max-width: 100%;
  color: #17315e;
}

.profile-branding-remove-form {
  display: flex;
  justify-content: flex-start;
}

.profile-branding-button {
  width: 220px;
  justify-content: center;
}

.profile-branding-hint {
  color: #6f809a;
  font-size: 0.86rem;
}

.profile-achievement-sections {
  padding: 0 18px 18px;
  display: grid;
  gap: 18px;
}

.profile-achievement-scope {
  display: grid;
  gap: 14px;
}

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

.profile-achievement-scope-head strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.18rem;
  color: #17315e;
}

.profile-achievement-scope-head span {
  color: #6b7c98;
  font-size: 0.92rem;
}

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

.profile-achievement-card {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid #dce7f5;
  background: linear-gradient(180deg, #fcfdff, #f4f8fe);
}

.profile-achievement-card.is-earned.theme-career {
  border-color: #bfe3d3;
  background: linear-gradient(180deg, #f7fcf9, #edf8f1);
}

.profile-achievement-card.is-earned.theme-company {
  border-color: #cde1ff;
  background: linear-gradient(180deg, #f7faff, #edf4ff);
}

.profile-achievement-card.is-locked {
  opacity: 0.9;
}

.profile-achievement-badge {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #dae7fb, #eef4ff);
  border: 1px solid #c8d8f4;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.profile-achievement-card.theme-career .profile-achievement-badge {
  background: linear-gradient(135deg, #d8f0e4, #effaf3);
  border-color: #bde0cc;
}

.profile-achievement-card.theme-company .profile-achievement-badge {
  background: linear-gradient(135deg, #d8e8ff, #eef4ff);
  border-color: #c5d8f7;
}

.profile-achievement-badge span {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.36rem;
  font-weight: 700;
  color: #17315e;
  letter-spacing: 0.06em;
}

.profile-achievement-copy {
  display: grid;
  gap: 8px;
}

.profile-achievement-title-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.profile-achievement-title-row strong {
  font-size: 1rem;
  color: #17315e;
}

.profile-achievement-title-row em {
  font-style: normal;
  font-weight: 700;
  color: #4d6f9a;
}

.profile-achievement-card.is-earned .profile-achievement-title-row em {
  color: #17804f;
}

.profile-achievement-copy > span {
  color: #60708b;
  line-height: 1.5;
}

.profile-achievement-progress {
  display: grid;
  gap: 4px;
  padding-top: 4px;
}

.profile-achievement-progress strong {
  color: #17315e;
  font-size: 0.95rem;
}

.profile-achievement-progress span {
  color: #6f809a;
  font-size: 0.85rem;
}

.profile-danger-copy {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 16px;
  border: 1px solid #f0c8c4;
  background: linear-gradient(180deg, #fff7f6, #fff1ef);
}

.profile-danger-copy strong {
  font-size: 0.96rem;
}

.profile-danger-copy span {
  color: #7d5660;
  line-height: 1.55;
}

.profile-danger-option {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #17315e;
  font-weight: 600;
}

.profile-danger-option input {
  width: 18px;
  height: 18px;
  accent-color: #c7332c;
}

.profile-danger-button {
  border-color: #de9595;
  background: linear-gradient(180deg, #e7a4a4, #cf7272);
  color: #fff;
  box-shadow: 0 14px 26px rgba(183, 101, 101, 0.22);
}

.profile-danger-button:hover,
.profile-danger-button:focus-visible {
  border-color: #d88585;
  background: linear-gradient(180deg, #ecb0b0, #c96868);
  color: #fff;
  box-shadow: 0 18px 30px rgba(183, 101, 101, 0.28);
}

.profile-action-button {
  width: 170px;
  justify-content: center;
}

.deactivate-btn {
  background: #D9534F;
  color: #FFFFFF;
  border: 1px solid #C94A46;
  box-shadow: none;
  border-radius: 14px;
  font-weight: 700;
  transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
}

.deactivate-btn:hover,
.deactivate-btn:focus-visible {
  background: #C9302C;
  border-color: #B92C28;
  color: #FFFFFF;
  box-shadow: none;
}

.deactivate-btn:active {
  background: #A94442;
  border-color: #A94442;
  color: #FFFFFF;
  transform: translateY(1px);
  box-shadow: none;
}

.license-preview {
  display: grid;
  gap: 8px;
  padding: 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f8fbff, #f1f6ff);
  border: 1px solid #d9e2f1;
}

.license-preview strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1.32rem;
  color: #17315e;
}

.sensitive-toggle-button {
  flex-shrink: 0;
  min-width: 190px;
}

.sensitive-value {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 1em;
  font-family: "Roboto Mono", "Consolas", monospace;
  letter-spacing: 0.08em;
  color: #28466f;
}

.sensitive-identity {
  display: inline;
  min-height: 0;
  gap: 0;
  font-family: inherit;
  letter-spacing: normal;
  color: inherit;
}

.license-panel.is-sensitive-hidden .sensitive-value {
  color: #6d7d97;
}

.license-preview span {
  color: #60708b;
}

.license-preview .outline-button,
.license-preview .profile-action-button {
  justify-self: start;
  margin-top: 8px;
}

.license-upload-form {
  padding: 0;
}

.flash-banner--success {
  background: linear-gradient(180deg, #f5fcf7, #edf9f0);
  border-color: #bee7cb;
}

.flash-banner--error {
  background: linear-gradient(180deg, #fff7f7, #fff1f1);
  border-color: #efcbcb;
}

.company-ops-shell {
  display: grid;
  gap: 16px;
}

.company-ops-nav-hub {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
  gap: 18px;
  padding: 22px 24px 18px;
  border-radius: 22px;
  border: 1px solid #d9e7f8;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow: 0 18px 36px rgba(15, 36, 73, 0.06);
}

.company-ops-nav-hub__section {
  display: grid;
  gap: 16px;
  padding-bottom: 14px;
  border-bottom: 4px solid #1d9450;
  min-width: 0;
}

.company-ops-nav-hub__section--market {
  border-bottom-color: #2d69ea;
}

.company-ops-nav-hub__header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
}

.company-ops-nav-hub__icon {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #eaf9ee 0%, #ddf4e5 100%);
  color: #0e8340;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
}

.company-logo-badge {
  overflow: hidden;
}

.company-logo-badge span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.company-logo-badge img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: inherit;
}

.company-logo-badge--has-image {
  padding: 0;
  background: #ffffff;
}

.company-ops-nav-hub__icon--market {
  background: linear-gradient(180deg, #edf4ff 0%, #e2ecff 100%);
  color: #2d69ea;
}

.company-ops-nav-hub__header strong {
  display: block;
  margin-bottom: 4px;
  color: #16693a;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.7rem;
  letter-spacing: 0.02em;
}

.company-ops-nav-hub__section--market .company-ops-nav-hub__header strong {
  color: #2d69ea;
}

.company-ops-nav-hub__header p {
  margin: 0;
  color: #5d7496;
  font-size: 1.02rem;
  line-height: 1.45;
}

.company-ops-nav-hub__links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.company-ops-nav-hub__section--company .company-ops-nav-hub__links {
  flex-wrap: nowrap;
  gap: 8px;
  justify-content: space-between;
}

.company-ops-nav-hub__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid transparent;
  color: #16693a;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 120ms ease, border-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
}

.company-ops-nav-hub__section--company .company-ops-nav-hub__link {
  flex: 0 1 auto;
  padding: 0 14px;
}

.company-ops-nav-hub__link:hover {
  border-color: rgba(22, 105, 58, 0.18);
  background: #f7fcf8;
}

.company-ops-nav-hub__link.is-active {
  border-color: #45b86c;
  background: linear-gradient(180deg, #f1fff5 0%, #e7f9ec 100%);
  box-shadow: 0 10px 24px rgba(23, 149, 70, 0.12);
}

.company-ops-nav-hub__link--market {
  color: #2d69ea;
}

.company-ops-nav-hub__link--market:hover {
  border-color: rgba(45, 105, 234, 0.18);
  background: #f6f9ff;
}

.company-ops-nav-hub__link--market.is-active {
  border-color: #5d8cff;
  background: linear-gradient(180deg, #f4f8ff 0%, #ebf2ff 100%);
  box-shadow: 0 10px 24px rgba(45, 105, 234, 0.12);
}

.company-ops-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 22px 24px;
  border-radius: 20px;
  border: 1px solid rgba(75, 146, 255, 0.16);
  background:
    radial-gradient(circle at top right, rgba(19, 133, 255, 0.12), transparent 36%),
    linear-gradient(180deg, rgba(10, 18, 32, 0.94), rgba(14, 24, 40, 0.94));
  color: #eef5ff;
}

.company-ops-hero h1 {
  margin: 8px 0 10px;
  font-size: 2rem;
  color: #ffffff;
}

.company-ops-hero p {
  margin: 0;
  max-width: 760px;
  color: #b8c8dd;
  line-height: 1.6;
}

.company-ops-hero-metrics {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
}

.company-ops-hero-metrics div {
  min-width: 140px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(76, 164, 255, 0.18);
  background: rgba(13, 31, 57, 0.72);
}

.company-ops-hero-metrics span {
  display: block;
  font-size: 0.76rem;
  color: #86a7ca;
  letter-spacing: 0.08em;
}

.company-ops-hero-metrics strong {
  display: block;
  margin-top: 6px;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.28rem;
  color: #ffffff;
}

.company-ops-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.company-ops-subnav-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.company-ops-subnav-group__label {
  color: #607796;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding-right: 4px;
}

.company-ops-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid #d9e4f4;
  background: #f7faff;
  color: #26456f;
  font-weight: 700;
  text-decoration: none;
}

.company-ops-subnav-link.is-active {
  border-color: #0e8e45;
  background: linear-gradient(180deg, #f0fff5, #e4f9ea);
  color: #0d7f3e;
  box-shadow: 0 12px 24px rgba(14, 142, 69, 0.12);
}

.company-ops-summary-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.company-ops-market-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.company-ops-section-block {
  display: grid;
  gap: 12px;
}

.company-ops-section-header {
  padding: 0 2px;
}

.company-ops-layout {
  align-items: start;
}

.company-ops-dashboard {
  display: grid;
  gap: 18px;
}

.company-ops-panel {
  padding: 18px;
  border-radius: 24px;
  border: 1px solid #d8e6f8;
  background:
    radial-gradient(circle at top right, rgba(51, 117, 255, 0.08), transparent 30%),
    linear-gradient(180deg, #ffffff, #fbfdff);
  box-shadow: 0 18px 38px rgba(33, 69, 122, 0.08);
}

.company-ops-panel--section {
  padding: 16px 18px 18px;
}

.company-ops-panel__heading {
  display: grid;
  grid-template-columns: 58px 1fr;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.company-ops-panel__heading h2 {
  margin: 0 0 4px;
  color: #18335f;
  font-size: 1.9rem;
  font-family: "Rajdhani", sans-serif;
}

.company-ops-panel__heading p {
  margin: 0;
  color: #617894;
  line-height: 1.55;
}

.company-ops-panel__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  border: 1px solid #d5e4fb;
  background: linear-gradient(180deg, #f7fbff, #edf4ff);
  color: #2a5fd0;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.company-ops-panel__icon--company {
  color: #2760d9;
}

.company-ops-panel__icon--market {
  color: #2967cc;
}

.company-ops-panel__icon--ops {
  color: #2c5ed4;
}

.company-ops-panel__icon--contracts {
  color: #2b64d4;
}

.company-ops-kpi-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 14px;
}

.company-ops-kpi-card {
  display: grid;
  gap: 10px;
  min-height: 156px;
  padding: 18px 18px 16px;
  border-radius: 20px;
  border: 1px solid #d8e6f8;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.company-ops-kpi-card--status {
  background: linear-gradient(180deg, #fbfffc, #f3fbf6);
}

.company-ops-kpi-card__label {
  display: block;
  color: #6b819d;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.company-ops-kpi-card strong {
  display: block;
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  line-height: 1;
}

.company-ops-kpi-card strong em {
  font-style: normal;
  font-size: 1.05rem;
  color: #627998;
}

.company-ops-kpi-card small {
  display: block;
  color: #607894;
  font-size: 0.92rem;
  line-height: 1.5;
}

.company-ops-meter {
  height: 8px;
  border-radius: 999px;
  background: #e5ecf6;
  overflow: hidden;
}

.company-ops-meter span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2e7fff, #2f55d4);
}

.company-ops-market-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.company-ops-market-card {
  display: grid;
  gap: 10px;
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid #d7e5f7;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  color: #15315d;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.company-ops-market-card:hover {
  transform: translateY(-1px);
  border-color: #b9cff3;
  box-shadow: 0 14px 28px rgba(36, 76, 137, 0.1);
}

.company-ops-market-card__label {
  display: block;
  color: #6b809a;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.company-ops-market-card strong {
  color: #18335f;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  line-height: 1;
}

.company-ops-market-card strong em {
  font-style: normal;
  font-size: 1rem;
  color: #2c67d3;
  margin-left: 4px;
}

.company-ops-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(340px, 0.9fr);
  gap: 18px;
  align-items: start;
}

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

.company-ops-overview-card {
  min-height: 126px;
  padding: 18px 20px;
  border-radius: 20px;
  border: 1px solid #d9e5f7;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96)),
    radial-gradient(circle at bottom right, rgba(56, 126, 255, 0.06), transparent 32%);
}

.company-ops-overview-card strong {
  display: block;
  margin-bottom: 10px;
  color: #18335f;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.36rem;
}

.company-ops-overview-card p,
.company-ops-overview-card small {
  display: block;
  margin: 0;
  color: #5f7794;
  line-height: 1.65;
}

.company-ops-overview-card p + p,
.company-ops-overview-card p + small {
  margin-top: 4px;
}

.company-ops-overview-card__lead {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 4px;
  color: #224f95;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
}

.company-ops-overview-card__lead span {
  color: #607894;
  font-size: 1rem;
  font-weight: 600;
}

.company-ops-overview-card--gauge {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 108px;
  align-items: center;
  gap: 16px;
}

.company-ops-circle {
  --ops-progress: 0;
  --ops-accent: #24a154;
  display: grid;
  align-items: center;
  justify-items: center;
  width: 108px;
  height: 108px;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, #ffffff 0 58%, transparent 59% 100%),
    conic-gradient(var(--ops-accent) calc(var(--ops-progress) * 1%), #e5ecf7 0);
  box-shadow: inset 0 0 0 1px rgba(17, 39, 77, 0.04);
}

.company-ops-circle--green {
  --ops-accent: #24a154;
}

.company-ops-circle--blue {
  --ops-accent: #2d7df8;
}

.company-ops-circle span {
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  line-height: 1;
}

.company-ops-circle em {
  font-style: normal;
  color: #2d8d50;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.company-ops-circle--blue em {
  color: #5d718f;
}

.company-ops-recommendation {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
  padding: 18px 20px;
  border-radius: 20px;
  border: 1px solid #cfe6d6;
  background: linear-gradient(180deg, #f8fff8, #f1faef);
}

.company-ops-recommendation__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: linear-gradient(180deg, #33a15e, #237447);
  color: #ffffff;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
}

.company-ops-recommendation strong {
  display: block;
  color: #19365e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.34rem;
}

.company-ops-recommendation p {
  margin: 4px 0 0;
  color: #5f7794;
  line-height: 1.6;
}

.company-ops-recommendation__link {
  color: #1f5fd1;
  font-weight: 700;
  text-decoration: none;
}

.company-ops-network-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
  padding: 18px 20px;
  border-radius: 20px;
  border: 1px solid #d9e5f7;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
}

.company-ops-network-card strong {
  display: block;
  margin-bottom: 8px;
  color: #18335f;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.34rem;
}

.company-ops-network-card p {
  margin: 0;
  color: #607894;
  line-height: 1.65;
}

.company-ops-network-card__visual {
  position: relative;
  min-height: 116px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 20% 48%, rgba(52, 124, 255, 0.75) 0 4px, transparent 5px),
    radial-gradient(circle at 52% 28%, rgba(52, 124, 255, 0.75) 0 4px, transparent 5px),
    radial-gradient(circle at 82% 62%, rgba(52, 124, 255, 0.75) 0 4px, transparent 5px),
    linear-gradient(180deg, #fafdff, #f2f7ff);
  overflow: hidden;
}

.company-ops-network-card__visual::before {
  content: "";
  position: absolute;
  inset: 22px 18px 18px;
  border-top: 2px dashed #b4cdf9;
  border-radius: 50%;
  opacity: 0.9;
}

.company-ops-network-card__visual span {
  position: absolute;
  height: 2px;
  background: linear-gradient(90deg, #b3caf7, #8eb3ff);
  transform-origin: left center;
  opacity: 0.85;
}

.company-ops-network-card__visual span:nth-child(1) {
  width: 102px;
  top: 46px;
  left: 54px;
  transform: rotate(-12deg);
}

.company-ops-network-card__visual span:nth-child(2) {
  width: 116px;
  top: 54px;
  left: 150px;
  transform: rotate(16deg);
}

.company-ops-network-card__visual span:nth-child(3) {
  width: 84px;
  top: 74px;
  left: 104px;
  transform: rotate(28deg);
}

.company-ops-panel--contracts {
  min-height: 100%;
}

.company-ops-contract-list {
  display: grid;
  gap: 12px;
}

.company-ops-contract-card {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #d8e5f6;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
}

.company-ops-contract-card strong {
  color: #18335f;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.3rem;
}

.company-ops-contract-card span {
  color: #607894;
  line-height: 1.55;
}

.company-ops-empty-card {
  display: grid;
  justify-items: center;
  gap: 16px;
  padding: 26px 22px 28px;
  min-height: 100%;
  border: 1px dashed #ccdaf0;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(77, 135, 255, 0.08), transparent 30%),
    linear-gradient(180deg, #fdfefe, #f7faff);
  text-align: center;
}

.company-ops-empty-card__visual {
  width: 100%;
  min-height: 210px;
  border-radius: 20px;
  background:
    radial-gradient(circle at 50% 34%, rgba(108, 155, 255, 0.22) 0 38px, transparent 40px),
    linear-gradient(180deg, #f8fbff, #eef4ff);
  position: relative;
  overflow: hidden;
}

.company-ops-empty-card__visual::before {
  content: "";
  position: absolute;
  width: 90px;
  height: 120px;
  left: 50%;
  top: 42%;
  transform: translate(-50%, -50%);
  border-radius: 18px;
  border: 6px solid #c9daf5;
  background: rgba(255, 255, 255, 0.72);
}

.company-ops-empty-card__visual::after {
  content: "";
  position: absolute;
  width: 46px;
  height: 46px;
  left: 50%;
  top: 56%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: linear-gradient(180deg, #4b82f0, #2b5fd2);
  box-shadow: 0 14px 24px rgba(43, 95, 210, 0.22);
}

.company-ops-empty-card strong {
  color: #18335f;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.8rem;
}

.company-ops-empty-card p {
  margin: 0;
  max-width: 320px;
  color: #617894;
  line-height: 1.7;
}

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

.company-ops-callout {
  display: grid;
  gap: 8px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #d4e3f7;
  background: linear-gradient(180deg, #fbfdff, #f2f7ff);
}

.aircraft-market-header-card {
  padding: 22px 24px 20px;
}

.aircraft-market-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.aircraft-market-summary-tiles {
  display: grid;
  grid-template-columns: repeat(4, minmax(132px, 1fr));
  gap: 10px;
}

.aircraft-market-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.aircraft-market-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid #d9e4f4;
  background: #fbfcff;
  color: #26456f;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(21, 44, 82, 0.06);
}

.aircraft-market-tab.is-active {
  border-color: #1f67ff;
  background: linear-gradient(180deg, #2d7eff, #1558dc);
  color: #ffffff;
  box-shadow: 0 14px 28px rgba(31, 103, 255, 0.24);
}

.aircraft-market-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.aircraft-market-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.aircraft-market-badge--good {
  background: linear-gradient(180deg, #f0fff5, #e2f8ea);
  border-color: #b7ebc5;
  color: #0d7f3e;
}

.aircraft-market-badge--warn {
  background: linear-gradient(180deg, #fff8ef, #ffeed7);
  border-color: #f2d1a3;
  color: #b25c00;
}

.aircraft-market-badge--blue {
  background: linear-gradient(180deg, #f0f6ff, #e4efff);
  border-color: #bfd5ff;
  color: #174ea6;
}

.aircraft-market-filter-form {
  grid-template-columns: repeat(4, minmax(170px, 1fr));
  margin-bottom: 18px;
}

.aircraft-market-filter-form button {
  align-self: end;
  min-height: 44px;
}

.aircraft-market-table .company-ops-table-actions {
  align-items: flex-start;
}

.aircraft-market-aircraft-cell strong {
  display: block;
  font-size: 0.98rem;
}

.aircraft-market-aircraft-cell span {
  display: block;
  margin-top: 4px;
  color: #6a7f9d;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.condition-meter {
  display: grid;
  gap: 6px;
  min-width: 104px;
}

.condition-meter strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
}

.condition-meter span {
  display: block;
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: #e7edf6;
  overflow: hidden;
}

.condition-meter span i {
  display: block;
  height: 100%;
  border-radius: 999px;
}

.condition-meter--good strong {
  color: #15803d;
}

.condition-meter--good span i {
  background: linear-gradient(90deg, #27c36a, #0f9f48);
}

.condition-meter--warn strong {
  color: #b26100;
}

.condition-meter--warn span i {
  background: linear-gradient(90deg, #ffc14d, #f59e0b);
}

.condition-meter--poor strong {
  color: #b42318;
}

.condition-meter--poor span i {
  background: linear-gradient(90deg, #ff7b72, #dc2626);
}

.muted-value {
  color: #7f8ea9;
  font-size: 0.88rem;
}

.ghost-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px dashed #ccd8ea;
  background: #fbfdff;
  color: #39537a;
  font-weight: 700;
  text-decoration: none;
}

.ghost-button--disabled {
  opacity: 0.66;
  cursor: default;
}

.aircraft-listing-editor {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 10px;
  margin-top: 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid #d9e4f4;
  background: linear-gradient(180deg, #fbfdff, #f4f8ff);
}

.aircraft-listing-editor label {
  display: grid;
  gap: 6px;
}

.aircraft-listing-editor label span {
  color: #607796;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.aircraft-listing-editor button {
  align-self: end;
  min-height: 42px;
}

.company-ops-callout strong {
  color: #17315e;
}

.company-ops-callout span {
  color: #60708b;
  line-height: 1.6;
}

.company-ops-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.company-base-map {
  min-height: 280px;
  border-radius: 18px;
  overflow: hidden;
}

.company-ops-preview-card--selected {
  border-color: #0e8e45;
  box-shadow: 0 16px 26px rgba(14, 142, 69, 0.12);
}

.company-ops-table-actions {
  display: grid;
  gap: 10px;
}

.company-ops-table-actions form {
  margin: 0;
}

.company-ops-table-actions .secondary-button,
.company-ops-table-actions .outline-button {
  width: 100%;
  justify-content: center;
}

.company-ops-reason-list {
  display: grid;
  gap: 6px;
}

.company-ops-reason-list span {
  display: block;
  padding-left: 14px;
  position: relative;
}

.company-ops-reason-list span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: #18a33f;
}

.company-ops-reason-list__item--bad::before {
  background: #d44f4f;
}

.company-ops-reason-list__item--warn::before {
  background: #e4a11b;
}

.company-ops-blocked-note {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(232, 101, 84, 0.28);
  background: linear-gradient(180deg, #fff7f5, #fff1ed);
}

.company-ops-blocked-note strong {
  color: #c04d3f;
  font-size: 0.95rem;
}

.company-ops-blocked-note span {
  color: #8f6159;
  font-size: 0.84rem;
}

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

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

.profile-form-field span {
  color: #17315e;
  font-weight: 700;
}

.profile-form-field input,
.profile-form-field select {
  min-height: 46px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid #d9e2f1;
  background: #fff;
  color: #17315e;
  font: inherit;
}

.profile-form-field input:focus,
.profile-form-field select:focus {
  outline: none;
  border-color: #3d7cff;
  box-shadow: 0 0 0 3px rgba(61, 124, 255, 0.14);
}

.airline-chip--cargo {
  background: linear-gradient(135deg, #103459, #0e223a);
  border-color: rgba(65, 150, 255, 0.28);
}

.fleet-overview-shell {
  display: grid;
  gap: 18px;
}

.fleet-overview-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 8px 2px 0;
}

.fleet-overview-header h2 {
  margin: 6px 0 8px;
  font-size: 2rem;
  color: #17315e;
}

.fleet-overview-header p {
  margin: 0;
  color: #617391;
  line-height: 1.6;
}

.fleet-overview-header__meta {
  display: grid;
  justify-items: end;
  gap: 4px;
  color: #7a8ba8;
  font-size: 0.84rem;
}

.fleet-overview-header__meta strong {
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
  color: #2b4f88;
  letter-spacing: 0.06em;
}

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

.fleet-kpi-card {
  padding: 18px 18px 16px;
  border-radius: 20px;
  border: 1px solid rgba(17, 50, 102, 0.08);
  background:
    radial-gradient(circle at top right, rgba(104, 155, 255, 0.12), transparent 38%),
    linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
  box-shadow: 0 16px 32px rgba(14, 29, 57, 0.08);
}

.fleet-kpi-card__label {
  display: block;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: #7a8ca8;
}

.fleet-kpi-card strong {
  display: block;
  margin-top: 10px;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  color: #15315c;
}

.fleet-kpi-card small {
  display: block;
  margin-top: 4px;
  color: #68809f;
  font-size: 0.84rem;
}

.fleet-kpi-card--emerald {
  background:
    radial-gradient(circle at top right, rgba(92, 214, 146, 0.16), transparent 38%),
    linear-gradient(180deg, #ffffff 0%, #f7fff9 100%);
}

.fleet-kpi-card--violet {
  background:
    radial-gradient(circle at top right, rgba(146, 118, 255, 0.16), transparent 38%),
    linear-gradient(180deg, #ffffff 0%, #fbf8ff 100%);
}

.fleet-kpi-card--teal {
  background:
    radial-gradient(circle at top right, rgba(74, 214, 201, 0.16), transparent 38%),
    linear-gradient(180deg, #ffffff 0%, #f4fffd 100%);
}

.fleet-kpi-card--amber {
  background:
    radial-gradient(circle at top right, rgba(255, 190, 92, 0.18), transparent 38%),
    linear-gradient(180deg, #ffffff 0%, #fffaf2 100%);
}

.fleet-kpi-card--sky {
  background:
    radial-gradient(circle at top right, rgba(76, 164, 255, 0.16), transparent 38%),
    linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
}

.fleet-callout-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(244, 120, 99, 0.32);
  background: linear-gradient(180deg, #fff9f7 0%, #fff4f1 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.fleet-callout-banner strong {
  display: block;
  color: #b84831;
  margin-bottom: 4px;
}

.fleet-callout-banner span {
  color: #8a5d53;
}

.fleet-callout-banner__tag {
  flex: 0 0 auto;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(244, 120, 99, 0.24);
  color: #c15740;
  font-size: 0.82rem;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.75);
}

.fleet-operations-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.9fr);
  gap: 18px;
}

.fleet-map-card,
.fleet-selected-card,
.fleet-filter-card,
.fleet-table-card {
  border-radius: 24px;
  border: 1px solid rgba(19, 49, 94, 0.08);
  background:
    radial-gradient(circle at top right, rgba(115, 170, 255, 0.12), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow: 0 18px 38px rgba(14, 29, 57, 0.08);
}

.fleet-map-card,
.fleet-selected-card,
.fleet-table-card {
  padding: 18px 18px 20px;
}

.fleet-filter-card {
  padding: 16px 18px;
}

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

.fleet-panel-header h3 {
  margin: 0;
  font-size: 1.26rem;
  color: #18335f;
}

.fleet-panel-header span {
  color: #647690;
  font-size: 0.87rem;
}

.fleet-map-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px 14px;
  color: #687a95;
  font-size: 0.78rem;
  font-weight: 700;
}

.fleet-map-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.fleet-map-legend__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.fleet-map-legend__dot--active {
  background: #2166ff;
}

.fleet-map-legend__dot--maintenance {
  background: #f59e0b;
}

.fleet-map-legend__dot--other {
  background: #94a3b8;
}

.fleet-overview-map.leaflet-route-map {
  height: 420px;
  margin-bottom: 0;
  border-radius: 22px;
}

.fleet-selected-card {
  display: grid;
  gap: 16px;
}

.fleet-selected-card__hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 165px;
  gap: 18px;
  align-items: center;
}

.fleet-selected-card__hero h3 {
  margin: 8px 0 2px;
  font-size: 1.85rem;
  color: #15315b;
}

.fleet-selected-card__hero strong {
  display: block;
  font-size: 1.02rem;
  color: #2a4a7a;
}

.fleet-selected-card__hero span:last-child {
  display: block;
  margin-top: 4px;
  color: #6b7d99;
  font-weight: 700;
}

.fleet-selected-card__visual {
  min-height: 108px;
  border-radius: 22px;
  border: 1px solid rgba(76, 164, 255, 0.18);
  background:
    radial-gradient(circle at 30% 25%, rgba(111, 179, 255, 0.22), transparent 30%),
    linear-gradient(145deg, #f7fbff 0%, #eaf2ff 100%);
  display: grid;
  place-items: center;
  color: #5f7fb6;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
}

.fleet-selected-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.fleet-selected-stats div {
  padding: 14px 12px;
  border-radius: 16px;
  border: 1px solid rgba(128, 154, 194, 0.18);
  background: rgba(255, 255, 255, 0.82);
}

.fleet-selected-stats span {
  display: block;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: #8395ae;
}

.fleet-selected-stats strong {
  display: block;
  margin-top: 8px;
  color: #19345f;
  font-size: 0.98rem;
}

.fleet-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.fleet-quick-actions form,
.fleet-quick-actions a,
.fleet-quick-actions button {
  margin: 0;
}

.fleet-quick-actions .secondary-button,
.fleet-quick-actions .outline-button {
  min-width: 132px;
  justify-content: center;
}

.crew-market-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 22px 24px 8px;
}

.crew-market-hero h2 {
  margin: 0 0 6px;
  font-size: 2.1rem;
  color: #15315f;
}

.crew-market-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  padding: 0 24px 18px;
}

.crew-market-stat {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #d9e6f7;
  background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
  box-shadow: 0 10px 24px rgba(33, 66, 124, 0.06);
}

.crew-market-stat__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #4c8dff, #204d9e);
  color: #ffffff;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.85rem;
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.crew-market-stat span {
  display: block;
  color: #5f7395;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
}

.crew-market-stat strong {
  display: block;
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  line-height: 1;
}

.crew-market-stat strong em {
  font-size: 1rem;
  font-style: normal;
  color: #5d7397;
  margin-left: 3px;
}

.crew-market-stat small {
  display: block;
  margin-top: 6px;
  color: #6b7e9d;
  font-size: 0.94rem;
}

.crew-market-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(320px, 0.75fr);
  gap: 22px;
  padding: 0 24px 24px;
}

.crew-market-list,
.crew-market-detail {
  border: 1px solid #d8e5f6;
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow: 0 16px 34px rgba(30, 56, 103, 0.08);
}

.crew-market-list__title,
.crew-market-detail__title {
  padding: 18px 18px 0;
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.35rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.crew-market-card {
  position: relative;
  display: grid;
  grid-template-columns: 60px minmax(170px, 1.05fr) minmax(160px, 0.9fr) repeat(3, minmax(74px, 0.42fr)) minmax(104px, 0.6fr) 84px;
  gap: 12px;
  align-items: center;
  margin: 14px 16px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid #d7e4f6;
  background: #ffffff;
  box-shadow: 0 8px 22px rgba(36, 69, 125, 0.06);
}

.crew-market-card.is-selected {
  border-color: #7ca9ff;
  box-shadow: 0 0 0 3px rgba(67, 119, 232, 0.12), 0 16px 28px rgba(36, 69, 125, 0.12);
}

.crew-market-card--no-avatar {
  grid-template-columns: minmax(210px, 1.18fr) minmax(160px, 0.9fr) repeat(3, minmax(74px, 0.42fr)) minmax(104px, 0.6fr) 84px;
}

.crew-market-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  border-radius: 20px 0 0 20px;
  background: #3d7cff;
}

.crew-market-card--dispatcher::before { background: #396dce; }
.crew-market-card--maintenance::before { background: #2f9a57; }
.crew-market-card--ops::before { background: #0e97a7; }
.crew-market-card--scheduler::before { background: #6843c6; }
.crew-market-card--pilot::before { background: #2858d4; }
.crew-market-card--generic::before { background: #7688a8; }

.crew-market-card__overlay {
  position: absolute;
  inset: 0;
  border-radius: 20px;
  z-index: 1;
}

.crew-market-card__avatar,
.crew-market-detail__avatar {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #ffffff;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.crew-market-card__avatar {
  width: 46px;
  height: 46px;
  font-size: 1.08rem;
  letter-spacing: 0.05em;
  background: radial-gradient(circle at 30% 30%, #4d88ff, #214d9f);
}

.crew-market-card--dispatcher .crew-market-card__avatar { background: radial-gradient(circle at 30% 30%, #5c87da, #284d93); }
.crew-market-card--maintenance .crew-market-card__avatar { background: radial-gradient(circle at 30% 30%, #4fc070, #247748); }
.crew-market-card--ops .crew-market-card__avatar { background: radial-gradient(circle at 30% 30%, #32bdd0, #0c7686); }
.crew-market-card--scheduler .crew-market-card__avatar { background: radial-gradient(circle at 30% 30%, #8b66ea, #5330ab); }
.crew-market-card--pilot .crew-market-card__avatar { background: radial-gradient(circle at 30% 30%, #4d88ff, #214d9f); }

.crew-market-card__main,
.crew-market-card__salary,
.crew-market-card__metric,
.crew-market-card__fit,
.crew-market-card__hire {
  position: relative;
  z-index: 2;
}

.crew-market-card__main strong {
  display: block;
  color: #132e5b;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.62rem;
  line-height: 1;
}

.crew-market-card__main span {
  display: block;
  color: #516683;
  margin-top: 3px;
  line-height: 1.25;
}

.crew-market-card__salary strong {
  display: block;
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.7rem;
  line-height: 1;
  white-space: nowrap;
}

.crew-market-card__salary strong em {
  font-style: normal;
  font-size: 0.92rem;
  color: #5e7598;
  margin-left: 3px;
}

.crew-market-card__salary span,
.crew-market-card__fit span {
  display: block;
  color: #677b98;
  margin-top: 5px;
  font-size: 0.84rem;
}

.crew-market-card__metric {
  padding: 10px 6px;
  border-radius: 14px;
  border: 1px solid #e1e7ef;
  text-align: center;
}

.crew-market-card__metric strong {
  display: block;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.32rem;
  line-height: 1;
}

.crew-market-card__metric span {
  display: block;
  margin-top: 4px;
  font-size: 0.88rem;
}

.crew-market-card__metric--safety {
  background: linear-gradient(180deg, #fff7ef, #fff3e3);
  border-color: #f3d1ac;
}

.crew-market-card__metric--safety strong,
.crew-market-card__metric--safety span {
  color: #df6713;
}

.crew-market-card__metric--reliability {
  background: linear-gradient(180deg, #fffaf0, #fff4df);
  border-color: #f0ddb0;
}

.crew-market-card__metric--reliability strong,
.crew-market-card__metric--reliability span {
  color: #cb8504;
}

.crew-market-card__metric--award {
  background: linear-gradient(180deg, #f4fff3, #ecfaeb);
  border-color: #cde8c8;
}

.crew-market-card__metric--award strong,
.crew-market-card__metric--award span {
  color: #2f8a4f;
}

.crew-market-card__fit strong {
  display: block;
  color: #2d5fb7;
  font-size: 0.94rem;
  line-height: 1.35;
  margin-top: 4px;
}

.crew-market-card__hire .secondary-button {
  width: 84px;
  min-width: 84px;
  padding-inline: 10px;
  background: linear-gradient(180deg, #2b61d4, #1b458f);
  border-color: #244f9c;
  color: #ffffff;
}

.crew-market-detail {
  padding-bottom: 20px;
}

.crew-market-detail__hero {
  display: grid;
  grid-template-columns: 84px 1fr;
  gap: 16px;
  align-items: center;
  padding: 18px;
}

.crew-market-detail__hero--pilot {
  grid-template-columns: 1fr;
}

.crew-market-detail__avatar {
  width: 84px;
  height: 84px;
  font-size: 1.45rem;
  letter-spacing: 0.05em;
  background: radial-gradient(circle at 30% 30%, #4d88ff, #214d9f);
}

.crew-market-detail__hero--dispatcher .crew-market-detail__avatar { background: radial-gradient(circle at 30% 30%, #5c87da, #284d93); }
.crew-market-detail__hero--maintenance .crew-market-detail__avatar { background: radial-gradient(circle at 30% 30%, #4fc070, #247748); }
.crew-market-detail__hero--ops .crew-market-detail__avatar { background: radial-gradient(circle at 30% 30%, #32bdd0, #0c7686); }
.crew-market-detail__hero--scheduler .crew-market-detail__avatar { background: radial-gradient(circle at 30% 30%, #8b66ea, #5330ab); }
.crew-market-detail__hero--pilot .crew-market-detail__avatar { background: radial-gradient(circle at 30% 30%, #4d88ff, #214d9f); }

.crew-market-detail__hero strong {
  display: block;
  color: #132e5b;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  line-height: 1;
}

.crew-market-detail__hero span,
.crew-market-detail__hero small {
  display: block;
  color: #597093;
  margin-top: 6px;
}

.crew-market-detail__stats {
  display: grid;
  gap: 10px;
  padding: 0 18px 18px;
}

.crew-market-detail__stats div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #4a6187;
  padding: 10px 12px;
  border: 1px solid #e2ebf7;
  border-radius: 14px;
  background: #ffffff;
}

.crew-market-detail__stats strong {
  color: #14305d;
}

.crew-market-detail__stats div > span:nth-child(2) {
  flex: 1;
  color: #4e6487;
  font-weight: 600;
}

.crew-market-detail__stat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 9px;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  font-size: 0.92rem;
  flex: 0 0 auto;
}

.crew-market-detail__stat-icon--salary {
  background: #e9f8ef;
  color: #2d8a50;
}

.crew-market-detail__stat-icon--safety {
  background: #eef8ef;
  color: #2f8a4f;
}

.crew-market-detail__stat-icon--reliability {
  background: #eef3ff;
  color: #315bc3;
}

.crew-market-detail__stat-icon--award {
  background: #f4efff;
  color: #6b46c6;
}

.crew-market-detail__stat-icon--seniority {
  background: #eef7ff;
  color: #1f6db0;
}

.crew-market-detail__block {
  padding: 0 18px 18px;
}

.crew-market-detail__label {
  display: block;
  color: #2d8d50;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.crew-market-detail__block strong {
  color: #18335f;
}

.crew-market-detail__ratings {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.crew-market-detail__rating-pill {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: #ebfbef;
  border: 1px solid #c8efd3;
  color: #2e8a4f;
  font-weight: 700;
  font-size: 0.92rem;
}

.crew-market-detail__block ul {
  margin: 0;
  padding-left: 18px;
  color: #556c8f;
  line-height: 1.65;
}

.crew-market-detail__block--strengths ul {
  list-style: none;
  padding-left: 0;
}

.crew-market-detail__block--strengths li {
  position: relative;
  padding-left: 22px;
  margin-bottom: 8px;
}

.crew-market-detail__block--strengths li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #35a15b;
  box-shadow: 0 0 0 3px #e7f6ec;
}

.crew-market-detail__hire {
  padding: 0 18px 0;
}

.crew-market-detail__hire .primary-button {
  width: 100%;
  justify-content: center;
}

.crew-market-detail__help {
  margin: 18px 18px 0;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid #dbe6f5;
  background: linear-gradient(180deg, #f8fbff 0%, #f3f8ff 100%);
}

.crew-market-detail__help strong {
  display: block;
  color: #16315d;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.12rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}

.crew-market-detail__help-row {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
  padding: 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid #e2ebf7;
}

.crew-market-detail__help-row + .crew-market-detail__help-row {
  margin-top: 10px;
}

.crew-market-detail__help-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
}

.crew-market-detail__help-icon--safety {
  background: #e9f8ef;
  color: #2d8a50;
}

.crew-market-detail__help-icon--reliability {
  background: #eef3ff;
  color: #315bc3;
}

.crew-market-detail__help-icon--award {
  background: #f4efff;
  color: #6b46c6;
}

.crew-market-detail__help-row span {
  display: block;
  color: #17315e;
  font-weight: 700;
  margin-bottom: 4px;
}

.crew-market-detail__help p {
  margin: 0;
  color: #556b8c;
  line-height: 1.5;
}

.crew-market-footnote {
  padding: 0 24px 22px;
  color: #5a6f92;
  font-size: 0.95rem;
}

@media (max-width: 1360px) {
  .crew-market-layout {
    grid-template-columns: 1fr;
  }

  .crew-market-card {
    grid-template-columns: 60px minmax(180px, 1.15fr) minmax(150px, 0.95fr) repeat(3, minmax(76px, 0.6fr));
  }

  .crew-market-card--no-avatar {
    grid-template-columns: minmax(180px, 1.15fr) minmax(150px, 0.95fr) repeat(3, minmax(76px, 0.6fr));
  }

  .crew-market-card__fit,
  .crew-market-card__hire {
    grid-column: span 3;
  }
}

@media (max-width: 1120px) {
  .crew-market-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .crew-market-card {
    grid-template-columns: 60px 1fr 1fr;
  }

  .crew-market-card--no-avatar {
    grid-template-columns: 1fr 1fr;
  }

  .crew-market-card__salary,
  .crew-market-card__metric,
  .crew-market-card__fit,
  .crew-market-card__hire {
    grid-column: 2 / span 2;
  }
}

@media (max-width: 760px) {
  .crew-market-hero {
    flex-direction: column;
  }

  .crew-market-stats {
    grid-template-columns: 1fr;
  }

  .crew-market-card {
    grid-template-columns: 56px 1fr;
  }

  .crew-market-card--no-avatar {
    grid-template-columns: 1fr;
  }

  .crew-market-card__salary,
  .crew-market-card__metric,
  .crew-market-card__fit,
  .crew-market-card__hire {
    grid-column: 1 / -1;
  }
}

.fleet-reposition-card {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(143, 185, 245, 0.22);
  background: linear-gradient(180deg, rgba(245, 249, 255, 0.95), rgba(236, 244, 255, 0.95));
}

.fleet-reposition-card__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}

.fleet-reposition-card label {
  display: grid;
  gap: 6px;
}

.fleet-reposition-card label span {
  font-size: 0.78rem;
  font-weight: 700;
  color: #61708b;
}

.fleet-filter-grid {
  display: grid;
  grid-template-columns: 1.25fr repeat(4, minmax(0, 1fr)) auto;
  gap: 12px;
  align-items: end;
}

.fleet-filter-grid label {
  display: grid;
  gap: 6px;
}

.fleet-filter-grid label span {
  font-size: 0.78rem;
  font-weight: 700;
  color: #61708b;
}

.fleet-filter-grid__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 150px;
}

.text-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  color: #2b63c0;
  font-weight: 700;
  text-decoration: none;
}

.fleet-table-shell {
  overflow-x: auto;
}

.fleet-manifest-table__row--selected {
  background: linear-gradient(180deg, rgba(238, 246, 255, 0.88), rgba(246, 250, 255, 0.88));
}

.fleet-row-link {
  color: #245fca;
  font-weight: 800;
  text-decoration: none;
}

.fleet-row-link:hover {
  text-decoration: underline;
}

.fleet-aircraft-cell strong,
.fleet-aircraft-cell span {
  display: block;
}

.fleet-aircraft-cell strong {
  color: #17325f;
}

.fleet-aircraft-cell span {
  color: #7183a0;
  font-size: 0.84rem;
  margin-top: 4px;
}

.fleet-condition-cell {
  min-width: 110px;
}

.fleet-condition-cell strong {
  display: block;
  margin-bottom: 8px;
  color: #17315d;
}

.fleet-condition-bar {
  display: block;
  width: 100%;
  height: 7px;
  border-radius: 999px;
  background: #edf2fa;
  overflow: hidden;
}

.fleet-condition-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
}

.fleet-condition-bar--good i {
  background: linear-gradient(90deg, #17b26a, #39cc84);
}

.fleet-condition-bar--warn i {
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.fleet-condition-bar--poor i {
  background: linear-gradient(90deg, #ef4444, #fb7185);
}

.fleet-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.fleet-status-pill--active {
  background: rgba(22, 181, 103, 0.14);
  color: #14804a;
}

.fleet-status-pill--in_maintenance,
.fleet-status-pill--rented_out,
.fleet-status-pill--leased_out {
  background: rgba(245, 158, 11, 0.15);
  color: #b86a08;
}

.fleet-status-pill--grounded,
.fleet-status-pill--sold,
.fleet-status-pill--lease_returned {
  background: rgba(239, 68, 68, 0.12);
  color: #bf3b3b;
}

.fleet-row-actions {
  color: #6e81a0;
  font-size: 0.84rem;
  font-weight: 700;
}

.fleet-manifest-table td small {
  display: block;
  margin-top: 4px;
  color: #7c8ca5;
}

@media (max-width: 1440px) {
  .bidding-layout {
    grid-template-columns: 1fr;
  }

  .bidding-layout .secondary-column {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.65fr);
    align-items: start;
    gap: 18px;
  }

  .bidding-layout .side-panel-card {
    position: static;
  }

  .bidding-filter-form {
    grid-template-columns: minmax(170px, 0.7fr) minmax(170px, 0.7fr) minmax(260px, 1fr) auto;
  }

  .company-ops-summary-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .company-ops-market-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .company-ops-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .company-ops-dashboard-grid {
    grid-template-columns: 1fr;
  }

  .company-ops-network-card {
    grid-template-columns: 1fr;
  }

  .aircraft-market-summary-tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .aircraft-market-filter-form,
  .aircraft-listing-editor {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .fleet-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .fleet-operations-grid {
    grid-template-columns: 1fr;
  }

  .fleet-filter-grid,
  .fleet-reposition-card__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .fleet-selected-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1120px) {
  .training-overview-grid,
  .training-support-grid,
  .training-mode-grid,
  .training-profile-strip,
  .training-active-grid,
  .training-profile-list,
  .bidding-summary-grid,
  .profile-form-grid,
  .profile-branding-grid,
  .profile-achievement-grid {
    grid-template-columns: 1fr;
  }

  .profile-branding-button {
    width: 100%;
  }

  .training-filter-field {
    max-width: none;
  }

  .training-command-card__header,
  .training-enrollment-card__header {
    align-items: flex-start;
  }

  .bidding-layout,
  .bidding-filter-form,
  .profile-layout {
    grid-template-columns: 1fr;
  }

  .side-panel-card {
    position: static;
  }

  .bidding-layout .secondary-column {
    grid-template-columns: 1fr;
  }

  .sensitive-toggle-button {
    width: 100%;
    min-width: 0;
  }

  .company-ops-health-grid,
  .company-ops-summary-grid {
    grid-template-columns: 1fr;
  }

  .company-ops-kpi-grid,
  .company-ops-market-grid {
    grid-template-columns: 1fr;
  }

  .company-ops-overview-grid,
  .company-ops-panel__heading,
  .company-ops-recommendation {
    grid-template-columns: 1fr;
  }

  .company-ops-overview-card--gauge {
    grid-template-columns: 1fr;
  }

  .company-ops-circle {
    margin-top: 8px;
  }

  .aircraft-market-header {
    grid-template-columns: 1fr;
    display: grid;
  }

  .aircraft-market-summary-tiles,
  .aircraft-market-filter-form,
  .aircraft-listing-editor {
    grid-template-columns: 1fr;
  }

  .company-ops-search-row {
    grid-template-columns: 1fr;
  }

  .company-ops-hero {
    grid-template-columns: 1fr;
    display: grid;
  }

  .company-ops-nav-hub {
    grid-template-columns: 1fr;
  }

  .company-ops-nav-hub__section {
    gap: 14px;
  }

  .company-ops-nav-hub__section--company .company-ops-nav-hub__links {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .company-ops-hero-metrics {
    justify-content: flex-start;
  }

  .company-ops-subnav-group {
    width: 100%;
  }

  .fleet-overview-header,
  .fleet-panel-header,
  .fleet-callout-banner,
  .fleet-selected-card__hero {
    grid-template-columns: 1fr;
    display: grid;
  }

  .fleet-overview-header__meta {
    justify-items: start;
  }

  .fleet-kpi-grid,
  .fleet-selected-stats,
  .fleet-filter-grid,
  .fleet-reposition-card__grid {
    grid-template-columns: 1fr;
  }

  .fleet-quick-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 820px) {
  .bidding-layout .secondary-column {
    grid-template-columns: 1fr;
  }

  .fleet-quick-actions {
    grid-template-columns: 1fr;
  }
}

.leaderboard-page {
  display: grid;
  gap: 18px;
}

.leaderboard-panel {
  padding: 18px;
  border-radius: 24px;
  border: 1px solid #d8e6f8;
  background:
    radial-gradient(circle at top right, rgba(51, 117, 255, 0.08), transparent 30%),
    linear-gradient(180deg, #ffffff, #fbfdff);
  box-shadow: 0 18px 38px rgba(33, 69, 122, 0.08);
}

.leaderboard-panel--hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 26px;
  background:
    radial-gradient(circle at top right, rgba(33, 165, 88, 0.12), transparent 24%),
    radial-gradient(circle at bottom left, rgba(44, 115, 218, 0.08), transparent 28%),
    linear-gradient(180deg, #ffffff, #f9fcff);
}

.leaderboard-panel__hero-copy {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.leaderboard-panel__hero-copy h1,
.leaderboard-panel__head h2 {
  margin: 0;
  color: #18335f;
  font-family: "Rajdhani", sans-serif;
}

.leaderboard-panel__hero-copy h1 {
  font-size: clamp(2rem, 4vw, 3rem);
}

.leaderboard-panel__hero-copy p,
.leaderboard-panel__head p {
  margin: 0;
  color: #617894;
  line-height: 1.55;
}

.leaderboard-panel__hero-chip {
  min-width: 220px;
  display: grid;
  gap: 4px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid #d9e8fb;
  background: linear-gradient(180deg, #f8fbff, #eef5ff);
  color: #18335f;
}

.leaderboard-panel__hero-chip strong {
  font-size: 1.12rem;
}

.leaderboard-panel__hero-chip span,
.leaderboard-panel__eyebrow {
  color: #6781a0;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.76rem;
  font-weight: 700;
}

.leaderboard-panel__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.leaderboard-panel__head > div {
  display: grid;
  gap: 6px;
}

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

.leaderboard-stat-card {
  display: grid;
  gap: 10px;
  min-height: 148px;
  padding: 18px 18px 16px;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(44, 115, 218, 0.10), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f9fcff 100%);
  border: 1px solid rgba(23, 49, 94, 0.08);
  box-shadow: 0 14px 36px rgba(14, 29, 57, 0.08);
}

.leaderboard-stat-card__label {
  color: #6b82a1;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.leaderboard-stat-card strong {
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 2.1rem;
  line-height: 1;
}

.leaderboard-stat-card small {
  color: #617894;
  line-height: 1.45;
}

.leaderboard-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 2.1fr) minmax(320px, 0.9fr);
  gap: 18px;
  align-items: start;
}

.leaderboard-content-grid__main,
.leaderboard-content-grid__side {
  display: grid;
  gap: 18px;
}

.leaderboard-table-wrap {
  overflow-x: auto;
}

.leaderboard-table {
  width: 100%;
  border-collapse: collapse;
}

.leaderboard-table thead th {
  padding: 0 12px 12px;
  color: #6b82a1;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: left;
  border-bottom: 1px solid #dbe8f8;
}

.leaderboard-table tbody td {
  padding: 16px 12px;
  border-bottom: 1px solid #ebf1fa;
  color: #17315e;
  vertical-align: middle;
}

.leaderboard-table tbody tr:last-child td {
  border-bottom: 0;
}

.leaderboard-table__row--current td {
  background: linear-gradient(180deg, rgba(33, 165, 88, 0.12), rgba(33, 165, 88, 0.06));
}

.leaderboard-table__row--company td {
  background: linear-gradient(180deg, rgba(44, 115, 218, 0.12), rgba(44, 115, 218, 0.06));
}

.leaderboard-table__separator td {
  text-align: center;
  color: #90a3bf;
  font-weight: 700;
}

.leaderboard-table__identity {
  display: grid;
  gap: 4px;
}

.leaderboard-table__identity strong {
  font-size: 1rem;
}

.leaderboard-table__identity span {
  color: #70839d;
  font-size: 0.88rem;
}

.leaderboard-table__metric--success {
  color: #17804f;
  font-weight: 700;
}

.leaderboard-rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 10px;
  border-radius: 14px;
  border: 1px solid #d6e4f8;
  background: linear-gradient(180deg, #f8fbff, #edf4ff);
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
}

.leaderboard-rank-badge.is-gold {
  border-color: #ead698;
  background: linear-gradient(180deg, #fff7dc, #f9ebba);
  color: #8c6420;
}

.leaderboard-rank-badge.is-silver {
  border-color: #d4dbe8;
  background: linear-gradient(180deg, #f8faff, #e9edf5);
  color: #506178;
}

.leaderboard-rank-badge.is-bronze {
  border-color: #e4c6a8;
  background: linear-gradient(180deg, #fff3ea, #f1ddc8);
  color: #855431;
}

.leaderboard-reliability {
  display: grid;
  gap: 6px;
}

.leaderboard-reliability strong {
  color: #17315e;
  font-size: 0.92rem;
}

.leaderboard-reliability span {
  display: block;
  width: 96px;
  height: 8px;
  border-radius: 999px;
  background: #e7eef9;
  overflow: hidden;
}

.leaderboard-reliability i {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #24b165, #6cd887);
}

.leaderboard-score-ring {
  display: grid;
  place-items: center;
  width: 180px;
  height: 180px;
  margin: 6px auto 18px;
  border-radius: 50%;
  border: 12px solid rgba(33, 165, 88, 0.16);
  box-shadow: inset 0 0 0 1px rgba(33, 165, 88, 0.12);
  background: radial-gradient(circle at center, #ffffff 48%, #f6fbf8 100%);
  text-align: center;
}

.leaderboard-score-ring--company {
  border-color: rgba(44, 115, 218, 0.16);
  box-shadow: inset 0 0 0 1px rgba(44, 115, 218, 0.12);
  background: radial-gradient(circle at center, #ffffff 48%, #f5f9ff 100%);
}

.leaderboard-score-ring__value {
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}

.leaderboard-score-ring__label {
  color: #17804f;
  font-size: 0.9rem;
  font-weight: 700;
}

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

.leaderboard-fact-grid div {
  display: grid;
  gap: 5px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid #deebf8;
  background: linear-gradient(180deg, #fcfdff, #f7fbff);
}

.leaderboard-fact-grid span {
  color: #71839e;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}

.leaderboard-fact-grid strong {
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.2rem;
}

.leaderboard-chart {
  min-height: 180px;
}

.leaderboard-chart svg {
  width: 100%;
  height: auto;
  display: block;
}

.leaderboard-chart__baseline {
  stroke: #d7e3f6;
  stroke-width: 1.5;
  stroke-dasharray: 6 6;
}

.leaderboard-chart__label {
  fill: #17315e;
  font-size: 14px;
  font-weight: 700;
}

.leaderboard-chart__legend {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 8px;
  color: #667f9f;
  font-size: 0.9rem;
}

.leaderboard-chart__legend strong {
  color: #17315e;
}

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

.leaderboard-achievement-card {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid #dce7f5;
  background: linear-gradient(180deg, #fcfdff, #f4f8fe);
}

.leaderboard-achievement-card--career {
  border-color: #bfe3d3;
  background: linear-gradient(180deg, #f7fcf9, #edf8f1);
}

.leaderboard-achievement-card--company {
  border-color: #cde1ff;
  background: linear-gradient(180deg, #f7faff, #edf4ff);
}

.leaderboard-achievement-card__badge {
  width: 68px;
  height: 68px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  border: 1px solid #c8d8f4;
  background: linear-gradient(135deg, #dae7fb, #eef4ff);
}

.leaderboard-achievement-card--career .leaderboard-achievement-card__badge {
  border-color: #bde0cc;
  background: linear-gradient(135deg, #d8f0e4, #effaf3);
}

.leaderboard-achievement-card__badge span {
  color: #17315e;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.32rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.leaderboard-achievement-card__copy {
  display: grid;
  gap: 8px;
}

.leaderboard-achievement-card__copy strong {
  color: #17315e;
  font-size: 1rem;
}

.leaderboard-achievement-card__copy span {
  color: #60708b;
  line-height: 1.5;
}

.leaderboard-achievement-card__copy em {
  color: #6f809a;
  font-style: normal;
  font-size: 0.84rem;
  font-weight: 700;
}

@media (max-width: 1320px) {
  .leaderboard-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .leaderboard-achievement-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1080px) {
  .leaderboard-content-grid {
    grid-template-columns: 1fr;
  }

  .leaderboard-panel--hero {
    flex-direction: column;
    align-items: flex-start;
  }

  .leaderboard-panel__hero-chip {
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 780px) {
  .leaderboard-stat-grid,
  .leaderboard-achievement-grid,
  .leaderboard-fact-grid {
    grid-template-columns: 1fr;
  }

  .leaderboard-panel__head,
  .leaderboard-chart__legend {
    flex-direction: column;
    align-items: flex-start;
  }

  .leaderboard-achievement-card {
    grid-template-columns: 56px minmax(0, 1fr);
  }

  .leaderboard-achievement-card__badge {
    width: 56px;
    height: 56px;
  }
}

.leaderboard-public-body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(53, 112, 208, 0.18), transparent 18%),
    linear-gradient(180deg, #08111d 0%, #0b1623 100%);
  color: #eef5ff;
  font-family: "Barlow", sans-serif;
}

.leaderboard-public-shell {
  width: min(1320px, calc(100% - 48px));
  margin: 0 auto;
  padding: 38px 0 56px;
  display: grid;
  gap: 26px;
}

.leaderboard-public-hero,
.leaderboard-public-table-card,
.leaderboard-public-stat-card {
  border: 1px solid rgba(78, 121, 183, 0.42);
  background: linear-gradient(180deg, rgba(21, 34, 51, 0.98), rgba(20, 32, 47, 0.98));
  box-shadow: 0 22px 46px rgba(0, 0, 0, 0.18);
}

.leaderboard-public-hero {
  border-radius: 22px;
  padding: 28px 28px 26px;
  display: grid;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.leaderboard-public-hero::before {
  content: "";
  position: absolute;
  inset: -10% auto auto -8%;
  width: 320px;
  height: 320px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(63, 139, 255, 0.24), transparent 68%);
  pointer-events: none;
}

.leaderboard-public-hero::after {
  content: "";
  position: absolute;
  inset: auto -8% -24% auto;
  width: 340px;
  height: 340px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(95, 211, 255, 0.14), transparent 70%);
  pointer-events: none;
}

.leaderboard-public-hero-top,
.leaderboard-public-hero-main {
  position: relative;
  z-index: 1;
}

.leaderboard-public-hero-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.leaderboard-public-hero-main {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.75fr);
  gap: 22px;
  align-items: end;
}

.leaderboard-public-hero-copy {
  display: grid;
  gap: 12px;
}

.leaderboard-public-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #8eb6e4;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.74rem;
  font-weight: 700;
}

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

.leaderboard-public-meta-card {
  min-height: 112px;
  padding: 18px 18px 16px;
  border-radius: 18px;
  border: 1px solid rgba(84, 129, 196, 0.36);
  background: linear-gradient(180deg, rgba(17, 28, 43, 0.95), rgba(13, 24, 38, 0.95));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  display: grid;
  gap: 8px;
}

.leaderboard-public-meta-card span {
  color: #8eb6e4;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
  font-weight: 700;
}

.leaderboard-public-meta-card strong {
  color: #f7fbff;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.35rem;
  line-height: 1.1;
}

.leaderboard-public-tabs {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.leaderboard-public-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid rgba(71, 121, 188, 0.42);
  color: #a9c8f5;
  text-decoration: none;
  font-weight: 700;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.leaderboard-public-tab:hover,
.leaderboard-public-tab:focus-visible {
  border-color: rgba(90, 157, 238, 0.72);
  color: #eef6ff;
}

.leaderboard-public-tab.is-active {
  background: linear-gradient(135deg, #2f8bff, #4ca3ff);
  border-color: rgba(102, 174, 255, 0.86);
  color: #fff;
}

.leaderboard-public-backlink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid rgba(88, 133, 198, 0.42);
  background: rgba(16, 30, 47, 0.78);
  color: #d8e9ff;
  text-decoration: none;
  font-weight: 700;
  transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.leaderboard-public-backlink:hover,
.leaderboard-public-backlink:focus-visible {
  border-color: rgba(102, 174, 255, 0.86);
  background: rgba(26, 50, 79, 0.9);
  color: #fff;
}

.leaderboard-public-hero h1 {
  margin: 0;
  color: #f4f8ff;
  font-family: "Rajdhani", sans-serif;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
}

.leaderboard-public-hero p {
  margin: 0;
  color: #b7cae6;
  font-size: 1.1rem;
  line-height: 1.6;
}

.leaderboard-public-stat-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.leaderboard-public-stat-card {
  min-height: 108px;
  border-radius: 18px;
  padding: 18px 20px;
  display: grid;
  gap: 12px;
  position: relative;
  overflow: hidden;
}

.leaderboard-public-stat-card::before,
.leaderboard-public-highlight-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: rgba(113, 163, 235, 0.7);
}

.leaderboard-public-stat-card.accent-blue::before,
.leaderboard-public-highlight-card.accent-blue::before {
  background: linear-gradient(180deg, #4ca3ff, #2f8bff);
}

.leaderboard-public-stat-card.accent-violet::before,
.leaderboard-public-highlight-card.accent-violet::before {
  background: linear-gradient(180deg, #b075ff, #8b5fff);
}

.leaderboard-public-stat-card.accent-green::before,
.leaderboard-public-highlight-card.accent-green::before {
  background: linear-gradient(180deg, #4de08b, #27c76f);
}

.leaderboard-public-stat-card.accent-cyan::before,
.leaderboard-public-highlight-card.accent-cyan::before {
  background: linear-gradient(180deg, #5fd3ff, #2bb7ee);
}

.leaderboard-public-stat-card.accent-gold::before,
.leaderboard-public-highlight-card.accent-gold::before {
  background: linear-gradient(180deg, #ffcf63, #f3af24);
}

.leaderboard-public-stat-card span {
  color: #8eb6e4;
  font-size: 0.95rem;
}

.leaderboard-public-stat-card strong {
  color: #ffffff;
  font-family: "Rajdhani", sans-serif;
  font-size: 2.2rem;
  line-height: 1;
}

.leaderboard-public-stat-card small {
  color: #6e89aa;
  line-height: 1.45;
}

.leaderboard-public-highlight-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.leaderboard-public-highlight-card {
  min-height: 132px;
  border-radius: 18px;
  padding: 20px 22px;
  border: 1px solid rgba(78, 121, 183, 0.42);
  background: linear-gradient(180deg, rgba(17, 29, 45, 0.98), rgba(13, 24, 38, 0.98));
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.16);
  display: grid;
  gap: 10px;
  position: relative;
  overflow: hidden;
}

.leaderboard-public-highlight-card__label {
  color: #8eb6e4;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.74rem;
  font-weight: 700;
}

.leaderboard-public-highlight-card strong {
  color: #f7fbff;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.9rem;
  line-height: 1;
}

.leaderboard-public-highlight-card small {
  color: #a7bdd9;
  line-height: 1.45;
}

.leaderboard-public-table-card {
  border-radius: 22px;
  padding: 22px;
  display: grid;
  gap: 18px;
}

.leaderboard-public-table-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.leaderboard-public-table-head h2 {
  margin: 4px 0 0;
  color: #f4f8ff;
  font-family: "Rajdhani", sans-serif;
  font-size: clamp(1.6rem, 2.5vw, 2.1rem);
}

.leaderboard-public-sort-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.leaderboard-public-sort {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid rgba(71, 121, 188, 0.42);
  color: #d4e6ff;
  text-decoration: none;
  font-weight: 600;
  background: rgba(27, 45, 66, 0.82);
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.leaderboard-public-sort:hover,
.leaderboard-public-sort:focus-visible {
  border-color: rgba(90, 157, 238, 0.72);
  color: #fff;
}

.leaderboard-public-sort.is-active {
  background: linear-gradient(135deg, #2f8bff, #4ca3ff);
  border-color: rgba(102, 174, 255, 0.86);
  color: #fff;
}

.leaderboard-public-table-wrap {
  overflow-x: auto;
}

.leaderboard-public-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1100px;
}

.leaderboard-public-table thead th {
  padding: 16px 14px;
  color: #8eb6e4;
  text-align: left;
  font-size: 0.95rem;
  font-weight: 600;
  border-bottom: 1px solid rgba(78, 121, 183, 0.35);
}

.leaderboard-public-table tbody td {
  padding: 15px 14px;
  color: #f1f6ff;
  border-bottom: 1px solid rgba(78, 121, 183, 0.18);
}

.leaderboard-public-table tbody tr:hover td {
  background: rgba(42, 73, 111, 0.22);
}

.leaderboard-public-table__money {
  font-weight: 700;
}

.leaderboard-public-table__money.is-positive {
  color: #7af18a;
}

.leaderboard-public-table__money.is-negative {
  color: #ff8f8f;
}

.leaderboard-public-table__money.is-neutral {
  color: #d8e9ff;
}

.leaderboard-public-table__metric {
  font-weight: 700;
}

.leaderboard-public-table__metric.is-primary {
  color: #63adff;
}

.leaderboard-public-table__metric.is-success {
  color: #61df84;
}

.leaderboard-public-table__metric.is-cyan {
  color: #69d6ff;
}

.leaderboard-public-identity {
  display: grid;
  gap: 4px;
}

.leaderboard-public-identity strong {
  color: #f7fbff;
}

.leaderboard-public-identity span {
  color: #8aa9cf;
  font-size: 0.86rem;
}

.leaderboard-public-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(92, 136, 200, 0.32);
  background: rgba(20, 40, 63, 0.8);
  color: #d8e9ff;
  font-size: 0.84rem;
  font-weight: 700;
}

.leaderboard-public-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(92, 136, 200, 0.34);
  background: rgba(19, 36, 56, 0.9);
  color: #dbe9ff;
  font-family: "Rajdhani", sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
}

.leaderboard-public-table__row.is-gold td {
  background: linear-gradient(180deg, rgba(88, 68, 15, 0.26), rgba(61, 48, 14, 0.16));
}

.leaderboard-public-table__row.is-gold .leaderboard-public-rank {
  border-color: rgba(255, 211, 92, 0.55);
  color: #ffe18b;
}

.leaderboard-public-table__row.is-silver td {
  background: linear-gradient(180deg, rgba(118, 130, 155, 0.14), rgba(58, 69, 92, 0.08));
}

.leaderboard-public-table__row.is-silver .leaderboard-public-rank {
  border-color: rgba(194, 208, 228, 0.48);
  color: #e5eefb;
}

.leaderboard-public-table__row.is-bronze td {
  background: linear-gradient(180deg, rgba(117, 72, 41, 0.18), rgba(69, 41, 25, 0.1));
}

.leaderboard-public-table__row.is-bronze .leaderboard-public-rank {
  border-color: rgba(209, 138, 89, 0.48);
  color: #efc19b;
}

@media (max-width: 1180px) {
  .leaderboard-public-hero-main,
  .leaderboard-public-highlight-grid {
    grid-template-columns: 1fr;
  }

  .leaderboard-public-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .leaderboard-public-shell {
    width: min(100% - 24px, 1320px);
    padding-top: 22px;
  }

  .leaderboard-public-stat-grid {
    grid-template-columns: 1fr;
  }

  .leaderboard-public-hero,
  .leaderboard-public-table-card {
    padding: 18px;
  }

  .leaderboard-public-hero-meta {
    grid-template-columns: 1fr;
  }

  .leaderboard-public-table-head {
    align-items: stretch;
  }
}
