/*
 Theme Name: Hello Elementor Naviolimited
 Template: hello-elementor
 Version: 1.0.0
 Text Domain: hello-elementor-naviolimited
*/

/*
 Global design tokens
 -------------------------------------------------- */
:root {
  /* Brand palette */
  --color-primary: #0057A3;
  --color-primary-hover: #1778C4;
  --color-accent: #F4CF4A; /* optional warm accent */

  /* Text colors */
  --color-text-dark: #002D5C; /* headings */
  --color-text-body: #0F1A2B; /* paragraph */
  --color-text-on-dark: #FFFFFF; /* on blue hero/footer */

  /* Backgrounds & UI */
  --color-bg-main: #F8FBFE; /* page */
  --color-bg-section: #EAF2FA; /* alternating sections */
  --color-border: #D7E5F3; /* dividers, input borders */

  /* Status */
  --color-success: #3CB371;
  --color-danger: #D9534F;

  /* Typography */
  --font-sans: 'Inter Tight', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, 'Apple Color Emoji','Segoe UI Emoji','Segoe UI Symbol', sans-serif;
  --base-font-size: 16px;
  --line-height: 1.6;

  /* Radii & shadows (optional) */
  --radius: 8px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 10px rgba(0,0,0,0.08);
  /* Header */
  --color-topbar: #1778C4; /* deep teal-like */
}

/*
 Base elements
 -------------------------------------------------- */
html { font-size: 100%; }
body {
  font-family: var(--font-sans);
  font-size: var(--base-font-size);
  line-height: var(--line-height);
  color: var(--color-text-body);
  background: var(--color-bg-main);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 { color: var(--color-text-dark); line-height: 1.2; }

a { color: var(--color-primary); text-decoration-color: color-mix(in oklab, var(--color-primary), #000 12%); }
a:hover, a:focus { color: var(--color-primary-hover); }

hr, .wp-block-separator { border-color: var(--color-border); }

/* Sections */
.section-alt, .has-alt-background { background: var(--color-bg-section); }

/*
 Buttons
 -------------------------------------------------- */
.wp-element-button,
button,
input[type="button"],
input[type="submit"],
.elementor-button {
  background: var(--color-primary);
  color: #fff;
  border: 1px solid var(--color-primary);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: background-color .2s ease, border-color .2s ease, box-shadow .2s ease, transform .02s ease;
}

.wp-element-button:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.elementor-button:hover {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.wp-element-button:active,
button:active,
input[type="button"]:active,
input[type="submit"]:active,
.elementor-button:active {
  transform: translateY(1px);
  box-shadow: var(--shadow-md);
}

/* Accents and utility classes */
.has-primary-color { color: var(--color-primary) !important; }
.has-primary-background-color { background-color: var(--color-primary) !important; color: #fff !important; }
.has-accent-background-color { background-color: var(--color-accent) !important; }
.has-section-background-color { background-color: var(--color-bg-section) !important; }
.has-border-color { border-color: var(--color-border) !important; }
.is-success { color: var(--color-success); }
.is-danger { color: var(--color-danger); }

/* Forms */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="password"],
textarea,
select {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
}

/* Dark sections (hero/footer) */
.on-dark, .site-footer, .hero--dark {
  color: var(--color-text-on-dark);
}

/*
 Header & navigation
 -------------------------------------------------- */
.nvl-topbar {
  background: var(--color-topbar);
  color: var(--color-text-on-dark);
  font-size: 0.875rem;
}
.nvl-topbar .container,
.site-header .container {
  max-width: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
}
.nvl-topbar .inner {
  display: flex;
  align-items: center;
  gap: 1.375rem;
  padding: 0.5rem 2.5rem;
}
.nvl-topbar .item {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  opacity: 0.95;
  color: inherit;
}
.nvl-topbar .item svg {
  flex: 0 0 auto;
  opacity: 0.9;
}
.nvl-topbar a {
  color: inherit;
  text-decoration: none;
}
.nvl-topbar .spacer {
  flex: 1 1 auto;
}
.nvl-topbar .track {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  padding: 0.35rem 0.9rem;
  background: rgba(255, 255, 255, 0.12);
  font-weight: 600;
  transition: background-color .2s ease, border-color .2s ease, transform .02s ease;
}
.nvl-topbar .track:hover,
.nvl-topbar .track:focus {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.36);
  transform: translateY(-1px);
}
.nvl-topbar .track-icon {
  display: inline-block;
  margin-left: 0.35rem;
  font-size: 1.1em;
}

.site-header {
  background: #fff;
  border-bottom: 1px solid var(--color-border);
  position: relative;
  z-index: 10;
}
.site-header .inner {
  display: flex;
  align-items: center;
  gap: 3.5rem;
  padding: 1.25rem 2.5rem;
}
.site-branding {
  flex: 0 0 auto;
}
.site-branding img {
  display: block;
  max-height: 52px;
  width: auto;
}
.site-branding .site-title {
  color: var(--color-text-dark);
  font-weight: 700;
  text-decoration: none;
}
.primary-nav {
  flex: 1 1 auto;
}
.primary-nav__toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: #fff;
  color: var(--color-text-dark);
  box-shadow: var(--shadow-sm);
  transition: background-color .2s ease, border-color .2s ease, transform .02s ease;
}
.primary-nav__toggle:hover,
.primary-nav__toggle:focus {
  background: var(--color-bg-section);
  border-color: color-mix(in oklab, var(--color-border), #000 15%);
}
.primary-nav__toggle {
  margin-left: auto;
}
.primary-nav__toggle-bars {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
}
.primary-nav__toggle-bars span {
  display: block;
  width: 18px;
  height: 2px;
  background: currentColor;
  border-radius: 999px;
  transition: transform .2s ease, opacity .2s ease;
}
.primary-nav__menu {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 2.25rem;
  margin: 0;
  padding: 0;
}
.primary-nav__menu > li > a {
  position: relative;
  display: inline-block;
  color: var(--color-text-body);
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: .01em;
  padding: 0.35rem 0;
  transition: color .15s ease;
}

.primary-nav__menu > li > a:hover::before,
.primary-nav__menu > li > a:focus::before {
  transform: scaleX(1);
}
.primary-nav__menu .current-menu-item > a {
  color: var(--color-primary);
}

.site-header.is-menu-open .primary-nav__toggle-bars span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.site-header.is-menu-open .primary-nav__toggle-bars span:nth-child(2) {
  opacity: 0;
}
.site-header.is-menu-open .primary-nav__toggle-bars span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

@media (prefers-reduced-motion: reduce) {
  .primary-nav__menu > li > a::before,
  .primary-nav__toggle,
  .primary-nav__toggle-bars span,
  .nvl-topbar .track {
    transition: none;
  }
}

@media (max-width: 1100px) {
  .site-header .inner {
    gap: 2rem;
    padding: 1rem 2rem;
  }
  .nvl-topbar .inner {
    padding: 0.5rem 2rem;
    gap: 1rem;
  }
}

@media (max-width: 992px) {
  .nvl-topbar {
    display: none;
  }
  .primary-nav__toggle {
    display: inline-flex;
  }
  .site-header .inner {
    position: relative;
  }
  .primary-nav {
    position: absolute;
    inset: 100% 0 auto 0;
    background: #fff;
    border-bottom: 1px solid var(--color-border);
    box-shadow: 0 16px 22px rgba(0, 0, 0, 0.06);
    display: none;
  }
  .site-header.is-menu-open .primary-nav {
    display: block;
  }
  .primary-nav__menu {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 1rem 1.5rem;
  }
  .primary-nav__menu > li + li {
    border-top: 1px solid var(--color-border);
  }
  .primary-nav__menu > li > a {
    padding: 0.75rem 0;
  }
}

@media (max-width: 768px) {
  .nvl-topbar .inner {
    flex-wrap: wrap;
    padding: 0.65rem 1.25rem;
    gap: 0.75rem 1rem;
  }
  .nvl-topbar .item {
    flex: 1 1 calc(50% - 1rem);
    min-width: 220px;
  }
  .nvl-topbar .spacer {
    display: none;
  }
  .site-header .inner {
    padding: 0.9rem 1.25rem;
  }
}

@media (max-width: 520px) {
  .nvl-topbar .item {
    flex-basis: 100%;
  }
  .primary-nav__menu {
    padding: 0.75rem 1rem;
  }
}


/*
 Grid + Cards (posts)
 -------------------------------------------------- */
.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 28px;
}

.card { background: #fff; border:1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: box-shadow .2s ease, transform .02s ease; }
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card-link { display:block; color: inherit; text-decoration: none; height:100%; }
.card-thumb { aspect-ratio: 16 / 10; overflow:hidden; margin:0; background: var(--color-bg-section); }
.card-thumb img { width:100%; height:100%; object-fit: cover; display:block; }
.card-body { padding: 16px; display:flex; flex-direction:column; gap:8px; }
.card-meta { font-size: 0.85rem; color: color-mix(in oklab, var(--color-text-body), #000 20%); display:flex; align-items:center; gap:8px; }
.card-title { font-size: 1.125rem; margin: 0; color: var(--color-text-dark); }
.card-excerpt { color: var(--color-text-body); opacity: 0.9; }
.card-cta { margin-top: auto; color: var(--color-primary); font-weight: 600; }

/* Pagination */
.pagination .page-numbers { display:inline-block; margin-right:8px; padding:8px 12px; border:1px solid var(--color-border); border-radius:6px; text-decoration:none; color: var(--color-text-body); }
.pagination .page-numbers.current, .pagination .page-numbers:hover { background: var(--color-primary); color:#fff; border-color: var(--color-primary); }

/* Footer styling */
/*
 Footer
 -------------------------------------------------- */
.site-footer {
  background: var(--color-text-dark);
  color: var(--color-text-on-dark);
}
.nvl-footbar {
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  background: color-mix(in oklab, var(--color-text-dark), #fff 15%);
}
.nvl-footbar .inner {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2.5rem;
  padding: 2.5rem 2.5rem;
  align-items: start;
}
.footbar-group {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}
.footbar-brand .brand {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text-on-dark);
  text-decoration: none;
}
.footbar-brand .tagline {
  margin: 0.5rem 0 0;
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.95rem;
}
.footbar-contact {
  min-width: 220px;
}
.footbar-heading {
  margin: 0 0 0.75rem;
  font-size: 0.875rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}
.footbar-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.85rem;
}
.footbar-list li {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.footbar-list .label {
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.65;
}
.footbar-list a {
  color: var(--color-text-on-dark);
  font-weight: 600;
  text-decoration: none;
}
.footbar-list a:hover,
.footbar-list a:focus {
  text-decoration: underline;
}
.footbar-cta {
  align-self: center;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background: var(--color-accent);
  color: var(--color-text-dark);
  border: 1px solid color-mix(in oklab, var(--color-accent), #000 12%);
  border-radius: 999px;
  padding: 0.65rem 1.35rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition: transform .02s ease, box-shadow .2s ease, background-color .2s ease, border-color .2s ease;
}
.footbar-cta:hover,
.footbar-cta:focus {
  background: color-mix(in oklab, var(--color-accent), #000 6%);
  border-color: color-mix(in oklab, var(--color-accent), #000 20%);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.footbar-cta .cta-icon {
  font-size: 1.2em;
}

.footbar-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem 1.5rem;
}
.footbar-menu__list li {
  list-style: none;
}
.footbar-menu__list a {
  color: var(--color-text-on-dark);
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.85rem;
  transition: opacity .2s ease;
}
.footbar-menu__list a:hover,
.footbar-menu__list a:focus {
  opacity: 0.8;
}
.footbar-menu__fallback {
  margin: 0;
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.7);
}

.nvl-copy {
  background: #fff;
  color: var(--color-text-body);
  border-top: 1px solid var(--color-border);
}
.nvl-copy .inner {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.9rem 2.5rem;
  text-align: center;
  font-size: 0.875rem;
  gap: 0.5rem;
}
.nvl-copy .brand {
  color: var(--color-text-dark);
  font-weight: 600;
  text-decoration: none;
}

@media (max-width: 1024px) {
  .nvl-footbar .inner {
    grid-template-columns: minmax(0, 1fr);
    gap: 2rem;
  }
  .footbar-group {
    gap: 1.5rem;
  }
  .footbar-menu__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .nvl-footbar .inner {
    grid-template-columns: 1fr;
    gap: 1.75rem;
    padding: 2rem 1.5rem;
  }
  .footbar-cta {
    justify-self: stretch;
    text-align: center;
  }
  .nvl-copy .inner {
    padding: 0.8rem 1.5rem;
  }
  .footbar-menu__list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .footbar-cta {
    width: 100%;
  }
}


/* ===== Full-width Page Hero with Breadcrumbs ===== */
.nvl-hero {
  height: 400px;
  width: 100%;
  display: grid;
  align-items: center;
  background: color-mix(in oklab, var(--color-primary), #001824 45%);
  color: var(--color-text-on-dark);
}
.nvl-hero .inner {
  max-width: 1200px;
  padding: 0 40px;
}

.nvl-hero__title {
  margin: 8px 0 0;
  font-size: clamp(32px, 4.5vw, 56px);
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -.01em;
  color: var(--color-text-on-dark);
  font-family: var(--font-sans);
}

/* Breadcrumbs */
.nvl-bc { display:flex; gap:10px; align-items:center; opacity:.95; font-size: 14px; }
.nvl-bc a { color: var(--color-text-on-dark); text-decoration: none; opacity: .9; }
.nvl-bc a:hover { opacity: 1; text-decoration: underline; }
.nvl-bc .sep { opacity:.6; margin: 0 4px; }
.nvl-bc [aria-current="page"] { opacity: 1; font-weight: 600; }

@media (max-width: 1024px) {
  .nvl-hero {
    height: 300px;
  }
  .nvl-hero .inner {
    padding: 0 28px;
  }
}

@media (max-width: 640px) {
  .nvl-hero {
    height: 220px;
  }
  .nvl-hero .inner {
    padding: 0 18px;
  }
  .nvl-hero__title {
    font-size: clamp(24px, 7vw, 32px);
  }
  .nvl-bc {
    font-size: 13px;
    gap: 6px;
  }
}


/* ── Freight-style contact form: floating labels + underline fields ── */
.qx-form{max-width:960px;margin:0 auto 56px;font-family:var(--font-sans)}
.qx-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:34px 42px}
.qx-field{position:relative;padding-top:12px}
.qx-field.qx-field--full{grid-column:1/-1}

/* inputs/textarea: only bottom border */
.qx-field input[type="text"],
.qx-field input[type="email"],
.qx-field input[type="tel"],
.qx-field textarea{
  width:100%;
  border:0;
  border-bottom:1.5px solid var(--color-border);
  background:transparent;
  color:var(--color-text-body);
  padding:16px 0 14px;
  line-height:1.5;
  outline:none;
  border-radius:0;
  transition:border-color .25s ease, color .2s ease, background-color .2s ease
}
.qx-field textarea{min-height:160px;resize:vertical}

/* animated active underline */
.qx-field::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:var(--color-primary);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s ease
}
.qx-field:focus-within::after{transform:scaleX(1)}

/* floating labels */
.qx-field label{
  position:absolute;left:0;top:18px;
  font-size:.95rem;letter-spacing:.01em;
  color:color-mix(in oklab,var(--color-text-body),#000 30%);
  pointer-events:none;transition:all .18s ease
}
.qx-field input:focus+label,
.qx-field textarea:focus+label,
.qx-field input:not(:placeholder-shown)+label,
.qx-field textarea:not(:placeholder-shown)+label{
  top:-6px;font-size:.75rem;letter-spacing:.02em;color:var(--color-text-dark)
}

/* states */
.qx-form ::placeholder{color:transparent} /* hide placeholder text entirely */
.qx-form .wpcf7-not-valid{border-bottom-color:var(--color-danger)!important}
.qx-form .wpcf7-response-output{
  margin:16px 0 0;padding:12px 14px;border-radius:var(--radius);
  background:var(--color-bg-section);border:1px solid var(--color-border);font-size:.925rem
}

/* big rounded accent button with subtle arrow */
.qx-actions{margin-top:8px}
.qx-btn,
input.qx-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 26px;border-radius:999px;border:1px solid color-mix(in oklab,var(--color-accent),#000 10%);
  background:var(--color-accent);color:var(--color-text-dark);
  font-weight:800;letter-spacing:.01em;box-shadow:var(--shadow-sm);
  cursor:pointer;transition:transform .02s ease, box-shadow .2s ease, background-color .2s ease, border-color .2s ease
}
.qx-btn::after{content:"→";transform:translateX(0);transition:transform .15s ease}
.qx-btn:hover{background:color-mix(in oklab,var(--color-accent),#000 6%);box-shadow:var(--shadow-md)}
.qx-btn:hover::after{transform:translateX(2px)}
.qx-btn:active{transform:translateY(1px)}

/* responsive */
@media (max-width:880px){
  .qx-grid{grid-template-columns:1fr;gap:28px}
}


/* ── Hero: featured image background + 70% blue overlay ───────────── */
.nvl-hero { position: relative; overflow: hidden; }
.nvl-hero.has-image {
  background: #000;                 /* fallback base */
  background-image: none;           /* cleared by default rule above */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--color-text-on-dark);
}

/* overlay sits above image, below text */
.nvl-hero__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: rgba(6, 54, 117, 0.6);
  background: linear-gradient(140deg, rgba(6, 54, 117, 0.65) 0%, rgba(0, 24, 50, 0.65) 100%);
}

/* keep text above overlay */
.nvl-hero .inner { position: relative; z-index: 1; }

/* ─── Fleet preview master/detail ───────────────────────────── */
.fleet {
  padding: 1.25rem 2.5rem;
}
.fleet-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 36px;
}
.fleet-preview {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 26px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.fleet-preview__title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text-dark);
}
.fleet-preview__hint {
  margin: 0;
  font-size: 0.9rem;
  color: color-mix(in oklab, var(--color-text-body), #000 25%);
}
.fleet-preview__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.fleet-preview__grid li {
  list-style: none;
}
.fleet-preview__item {
  position: relative;
  width: 100%;
  min-height: 112px;
  padding: 26px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: #fff;
  color: var(--color-text-dark);
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: border-color .22s ease, box-shadow .22s ease, transform .18s ease, color .18s ease;
}
.fleet-preview__item span {
  position: relative;
  z-index: 1;
  transition: color .2s ease, opacity .2s ease;
}
.fleet-preview__item::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(0, 87, 163, 0.96) 0%, rgba(23, 120, 196, 0.92) 60%, rgba(0, 87, 163, 0.88) 100%);
  opacity: 0;
  background-size: 210% 210%;
  background-position: right bottom;
  transition: opacity .25s ease, background-position .45s ease;
  z-index: 0;
  will-change: opacity, background-position;
}
.fleet-preview__item::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  width: 60px;
  height: 60px;
  background: #fff;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  border-top-left-radius: calc(var(--radius) + 2px);
  pointer-events: none;
  z-index: 2;
}
.fleet-preview__item:hover,
.fleet-preview__item:focus-visible,
.fleet-preview__item.is-active {
  color: var(--color-text-on-dark);
  border-color: color-mix(in oklab, var(--color-primary), #ffffff 35%);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.fleet-preview__item:hover::after,
.fleet-preview__item:focus-visible::after,
.fleet-preview__item.is-active::after {
  opacity: 1;
  background-position: right top;
}
.fleet-preview__item:hover .fleet-preview__type,
.fleet-preview__item:focus-visible .fleet-preview__type,
.fleet-preview__item.is-active .fleet-preview__type,
.fleet-preview__item:hover .fleet-preview__year,
.fleet-preview__item:focus-visible .fleet-preview__year,
.fleet-preview__item.is-active .fleet-preview__year {
  opacity: 0.85;
  color: rgba(255, 255, 255, 0.9);
}
.fleet-preview__item:focus-visible {
  outline: 3px solid color-mix(in oklab, var(--color-primary), #ffffff 35%);
  outline-offset: 2px;
}
.fleet-preview__name {
  font-size: 1.02rem;
  font-weight: 700;
}
.fleet-preview__type {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: color-mix(in oklab, var(--color-text-body), #000 35%);
}
.fleet-preview__year {
  font-size: 0.85rem;
  color: var(--color-primary);
}

.fleet-detail {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 22px 22px 24px;
  position: relative;
  overflow: hidden;
  position: sticky;
  top: clamp(72px, 10vw, 120px);
  max-height: calc(100vh - clamp(120px, 15vw, 200px));
}
.fleet-detail__panel {
  display: grid;
  gap: 0.65rem;
  opacity: 1;
  transform: translateY(0);
  transition: opacity .25s ease, transform .25s ease;
  overflow-y: auto;
  padding-right: 6px;
  max-height: 100%;
  scrollbar-gutter: stable;
  flex: 1 1 auto;
  -webkit-overflow-scrolling: touch;
}
.fleet-detail__panel.is-transitioning {
  opacity: 0;
  transform: translateY(18px);
}
.fleet-detail__badge-wrap {
  display: inline-flex;
}
.fleet-detail__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0.18rem 0.6rem;
  border-radius: 999px;
  background: var(--color-bg-section);
  color: var(--color-primary);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.fleet-detail__badge-wrap {
  margin-bottom: 0.25rem;
}
.fleet-detail__title {
  margin: 0 0 0.35rem;
  font-size: clamp(28px, 3.6vw, 40px);
  color: var(--color-text-dark);
  font-weight: 700;
}
.fleet-detail__subtitle {
  margin: 0 0 0.35rem;
  font-size: 0.9rem;
  color: color-mix(in oklab, var(--color-text-body), #000 25%);
}
.fleet-detail__gallery {
  margin: 0.5rem 0 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.fleet-detail__gallery-track {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.75rem;
}
.fleet-detail__gallery-item {
  margin: 0;
  border-radius: calc(var(--radius) - 2px);
  overflow: hidden;
  background: var(--color-bg-section);
  box-shadow: var(--shadow-sm);
}
.fleet-detail__gallery-item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 16 / 9;
}
.fleet-detail__specs {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.6rem 0.85rem;
}
.fleet-detail__specs dt {
  margin: 0;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in oklab, var(--color-text-body), #000 40%);
}
.fleet-detail__specs dd {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text-dark);
}
.fleet-detail__notes {
  border-top: 1px solid var(--color-border);
  padding-top: 0.75rem;
}
.fleet-detail__notes h4 {
  margin: 0 0 0.4rem;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in oklab, var(--color-text-body), #000 35%);
}
.fleet-detail__notes p {
  margin: 0;
  color: var(--color-text-body);
  line-height: 1.45;
}
.fleet-detail__empty,
.fleet-empty {
  margin: 40px 0;
  text-align: center;
  font-size: 1rem;
  color: color-mix(in oklab, var(--color-text-body), #000 30%);
}
[data-field-wrapper].is-hidden {
  display: none;
}

@media (prefers-reduced-motion: reduce) {
  .fleet-detail__panel,
  .fleet-preview__item {
    transition: none;
  }
}

@media (max-width: 1024px) {
  .fleet-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .fleet-preview,
  .fleet-detail {
    padding: 24px 20px;
  }
  .fleet-preview__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fleet-detail {
    position: static;
    max-height: none;
  }
  .fleet-detail__panel {
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }
}

@media (max-width: 640px) {
  .fleet {
    padding: 48px 0;
  }
  .fleet-preview__grid {
    grid-template-columns: 1fr;
  }
  .fleet-preview__item {
    min-height: 104px;
  }
  .fleet-detail {
    padding: 24px 20px;
  }
  .fleet-detail__title {
    font-size: clamp(24px, 7vw, 32px);
  }
}
