﻿/* ================================================================
   EBMENS GROUP LTD â€” Design System v3
   Fonts: Barlow Condensed + DM Sans + Instrument Serif
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Instrument+Serif:ital@1&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:       #0B1F4B;
  --navy-mid:   #122566;
  --blue:       #1847C8;
  --blue-light: #EBF0FF;
  --blue-soft:  #F5F7FF;
  --white:      #FFFFFF;
  --off-white:  #FAFAF8;
  --grey-50:    #F6F7F9;
  --grey-100:   #ECEEF2;
  --grey-200:   #D8DCE6;
  --grey-400:   #9BA4B8;
  --grey-600:   #4B5468;
  --grey-800:   #252D40;
  --grey-900:   #0F1523;
  --shadow-sm:  0 1px 4px rgba(11,31,75,.07),0 0 0 1px rgba(11,31,75,.04);
  --shadow-md:  0 4px 20px rgba(11,31,75,.10),0 1px 4px rgba(11,31,75,.06);
  --shadow-lg:  0 16px 48px rgba(11,31,75,.14),0 2px 8px rgba(11,31,75,.06);
  --radius-sm:  10px;
  --radius-md:  14px;
  --radius-lg:  20px;
  --radius-xl:  28px;
  --ff:         'DM Sans', system-ui, sans-serif;
  --ff-display: 'Barlow Condensed', system-ui, sans-serif;
  --ff-serif:   'Instrument Serif', Georgia, serif;
}

html { scroll-behavior: smooth; }
body {
  background: var(--white);
  color: var(--grey-900);
  font-family: var(--ff);
  font-weight: 400;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

/* â”€â”€ PROGRESS BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#progress-bar {
  position: fixed; top: 0; left: 0; z-index: 200;
  height: 2px;
  background: linear-gradient(90deg, var(--blue) 0%, rgba(24,71,200,.5) 100%);
  width: 0%; transition: width .1s linear;
}

/* â”€â”€ NAV â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
nav {
  position: sticky; top: 0; z-index: 100;
  background: linear-gradient(180deg,rgba(8,12,24,.98) 0%,rgba(10,15,30,.95) 100%);
  backdrop-filter: blur(24px) saturate(135%);
  border-bottom: 1px solid rgba(255,255,255,.12);
  padding: 0 3.4rem;
  display: flex; align-items: center; gap: 2.25rem;
  height: 86px;
  transition: box-shadow .3s, border-color .3s, background .3s;
}
nav.scrolled {
  box-shadow: 0 14px 38px rgba(0,0,0,.28);
  border-bottom-color: rgba(255,255,255,.16);
}

.nav-logo {
    color: #fff; text-decoration: none; white-space: nowrap; flex-shrink: 0;
    display: inline-flex; align-items: center; min-width: 0;
  }
.nav-logo-image { display:block; height:34px; width:auto; max-width:240px; object-fit:contain; }
.nav-logo-ltd {
    font-size: .48em; font-weight: 600; color: rgba(255,255,255,.46); letter-spacing: .12em;
  }

.nav-links { display: flex; gap: .08rem; list-style: none; flex: 1; justify-content: flex-end; align-items: center; margin: 0 0 0 auto; padding: 0; }
.nav-links > li { position: relative; list-style: none; }
.nav-dropdown { display: flex; align-items: center; }
.nav-links a {
  position: relative;
  font-family: 'DM Sans', sans-serif; font-size: .9rem; font-weight: 500; letter-spacing: 0;
  color: rgba(255,255,255,.78); text-transform: none;
  text-decoration: none; padding: .48rem .72rem .82rem;
  transition: color .22s ease, opacity .22s ease, transform .22s ease; white-space: nowrap;
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: .72rem;
  right: .72rem;
  bottom: .34rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg,#ffffff 0%,#93c5fd 100%);
  opacity: 0;
  transform: scaleX(.35);
  transform-origin: center;
  transition: opacity .22s ease, transform .22s ease;
}
.nav-links a:hover {
  color: #fff; transform: translateY(-1px);
}
.nav-links a:hover::after {
  opacity: .45;
  transform: scaleX(.72);
}
.nav-links a.active {
  color: #fff;
}
.nav-links a.active::after {
  opacity: 1;
  transform: scaleX(1);
}
.nav-dropdown-toggle {
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  padding: .48rem .78rem .82rem;
  margin: 0;
  border: none;
  background: none;
  color: rgba(255,255,255,.78);
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem;
  font-weight: 500;
  letter-spacing: 0;
  cursor: pointer;
  transition: color .22s ease, transform .22s ease;
  white-space: nowrap;
  outline: none;
}
.nav-dropdown-toggle::after {
  content: "";
  position: absolute;
  left: .78rem;
  right: .78rem;
  bottom: .34rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg,#ffffff 0%,#93c5fd 100%);
  opacity: 0;
  transform: scaleX(.35);
  transform-origin: center;
  transition: opacity .22s ease, transform .22s ease;
}
.nav-dropdown-toggle:hover,
.nav-dropdown:hover .nav-dropdown-toggle,
.nav-dropdown-toggle.active {
  color: #fff;
}
.nav-dropdown-toggle:hover::after,
.nav-dropdown:hover .nav-dropdown-toggle::after,
.nav-dropdown-toggle.active::after {
  opacity: 1;
  transform: scaleX(.72);
}
.nav-dropdown-toggle.active::after {
  transform: scaleX(1);
}
.nav-dropdown-caret {
  width: 8px;
  height: 8px;
  border-right: 1.75px solid currentColor;
  border-bottom: 1.75px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  opacity: .72;
  transition: transform .2s ease;
}
.nav-dropdown:hover .nav-dropdown-caret {
  transform: rotate(225deg) translateY(-1px);
}
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  min-width: 220px;
  display: flex;
  flex-direction: column;
  padding: .48rem;
  border-radius: 16px;
  background: rgba(10,15,30,.98);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 44px rgba(0,0,0,.34);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(-50%) translateY(8px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
  z-index: 120;
}
.nav-dropdown:hover .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-dropdown-menu a {
  display: flex;
  align-items: center;
  gap: 0;
  width: 100%;
  padding: .72rem .78rem;
  border-radius: 12px;
  color: rgba(255,255,255,.8);
  text-decoration: none;
  font-family: 'DM Sans', sans-serif;
  font-size: .85rem;
  font-weight: 500;
}
.nav-dropdown-menu a::after {
  display: none;
}
.nav-dropdown-menu a:hover,
.nav-dropdown-menu a.active {
  background: rgba(255,255,255,.08);
  color: #fff;
  transform: none;
}
.nav-actions { display: flex; align-items: center; gap: .55rem; margin-left: .95rem; flex-shrink: 0; }
.nav-mobile-tools { display: none; align-items: center; gap: .55rem; margin-left: auto; }

.btn-outline {
  padding: .64rem 1rem; border: 1.5px solid var(--grey-200); border-radius: 10px;
  font-family: 'DM Sans', sans-serif; font-size: .82rem; font-weight: 600; color: rgba(255,255,255,.94); background: none;
  cursor: pointer; text-decoration: none; transition: all .2s;
}
.btn-outline:hover { border-color: rgba(255,255,255,.92); color: #fff; background: rgba(255,255,255,.08); }
.btn-outline.active { border-color: rgba(255,255,255,.92); color: #fff; background: rgba(255,255,255,.12); }

.btn-navy {
  padding: .64rem 1rem; background: var(--navy); border: none; border-radius: 10px;
  font-family: 'DM Sans', sans-serif; font-size: .82rem; font-weight: 600; color: #fff; cursor: pointer;
  text-decoration: none; transition: all .2s;
  box-shadow: none;
}
.btn-navy:hover { background: var(--navy-mid); transform: translateY(-1px); }

/* Mobile hamburger */
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px; cursor: pointer;
  padding: 6px; border: none; background: none; margin-left: 0;
}
.nav-hamburger span {
  display: block; width: 22px; height: 2px;
  background: #fff; border-radius: 2px; transition: all .3s;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav {
  display: none;
  position: fixed; top: 86px; left: 0; right: 0; z-index: 99;
  background: rgba(10,15,30,.99); backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: .9rem 1.1rem 1.1rem;
  box-shadow: 0 12px 34px rgba(0,0,0,.32);
  transform: translateY(-8px); opacity: 0;
  transition: all .25s cubic-bezier(.16,1,.3,1);
}
.mobile-nav.open { transform: translateY(0); opacity: 1; display: block; }
.mobile-nav ul { list-style: none; display: flex; flex-direction: column; gap: .08rem; margin-bottom: .95rem; }
.mobile-nav ul a {
  display: block; padding: .5rem .68rem; font-family: var(--ff); font-size: .88rem; font-weight: 500;
  color: rgba(255,255,255,.82); text-decoration: none; border-radius: 8px; transition: all .15s;
}
.mobile-nav ul a:hover, .mobile-nav ul a.active { background: rgba(255,255,255,.08); color: #fff; font-weight: 500; }
.mobile-nav-more-wrap { padding: 0 .1rem; }
.mobile-nav-more {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  overflow: hidden;
  background: rgba(255,255,255,.03);
}
.mobile-nav-more summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .62rem .72rem;
  font-size: .82rem;
  font-weight: 600;
  color: rgba(255,255,255,.82);
}
.mobile-nav-more summary::-webkit-details-marker { display: none; }
.mobile-nav-more summary::after {
  content: '+';
  font-size: 1rem;
  line-height: 1;
  color: rgba(255,255,255,.52);
}
.mobile-nav-more[open] summary::after {
  content: '-';
}
.mobile-nav-sublist {
  display: flex;
  flex-direction: column;
  gap: .08rem;
  padding: .22rem .3rem .3rem;
  border-top: 1px solid rgba(255,255,255,.08);
  background: transparent;
}
.mobile-nav-sublist a {
  font-size: .82rem;
  padding: .44rem .54rem;
}
.mobile-nav-actions { display: flex; gap: .65rem; }
.mobile-nav-actions a { flex: 1; text-align: center; }

/* â”€â”€ HERO â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hero {
  position: relative; min-height: 620px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  overflow: hidden; padding: 5rem 2rem 6rem;
  background:
    linear-gradient(180deg, rgba(8,18,46,.55) 0%, rgba(8,18,46,.3) 40%, rgba(8,18,46,.55) 100%),
    url('https://images.unsplash.com/photo-1547471080-7cc2caa01a7e?w=1600&q=80') center/cover no-repeat;
}
.hero::after {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  background-repeat: repeat; background-size: 128px; pointer-events: none;
}
.hero-content { position: relative; z-index: 2; text-align: center; max-width: 860px; }

.hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(255,255,255,.15); color: rgba(255,255,255,.95);
  border: 1px solid rgba(255,255,255,.25); backdrop-filter: blur(8px);
  font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: .4rem 1rem; border-radius: 100px; margin-bottom: 1.5rem;
}
.hero-badge-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #FFB347; box-shadow: 0 0 8px rgba(255,179,71,.8);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.8)} }

.hero-title {
  font-family: var(--ff-display);
  font-size: clamp(3rem, 6.5vw, 5.5rem);
  font-weight: 800; line-height: .95; letter-spacing: -.01em;
  color: #fff; margin-bottom: 1rem; text-transform: uppercase;
  text-shadow: 0 2px 24px rgba(0,0,0,.3);
}
.hero-title em {
  font-family: var(--ff-serif); font-style: italic; color: #FFD580;
  font-weight: 400; text-transform: none; letter-spacing: -.02em;
}
.hero-title .blue-line {
  display: block; color: #fff;
  background: linear-gradient(90deg, #fff 0%, #C8D8FF 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-sub {
  font-size: 1.05rem; font-weight: 400; color: rgba(255,255,255,.78);
  line-height: 1.65; max-width: 480px; margin: 0 auto 2.75rem;
  text-shadow: 0 1px 8px rgba(0,0,0,.3);
}

/* â”€â”€ SEARCH CARD â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.search-card {
  background: var(--white); border-radius: var(--radius-xl);
  box-shadow: 0 24px 64px rgba(11,31,75,.16), 0 4px 16px rgba(11,31,75,.08), 0 0 0 1px rgba(11,31,75,.06);
  width: 100%; max-width: 860px; overflow: hidden;
  animation: slideUp .8s cubic-bezier(.16,1,.3,1) .2s both;
}
@keyframes slideUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

.search-tabs {
  display: flex; padding: 1.1rem 1.4rem 0; gap: .2rem;
  border-bottom: 1px solid var(--grey-100); background: var(--grey-50);
}
.stab {
  display: flex; align-items: center; gap: .45rem;
  padding: .55rem 1rem .75rem;
  font-family: var(--ff); font-size: .78rem; font-weight: 600; color: var(--grey-400);
  border: none; background: none; cursor: pointer; border-radius: 8px 8px 0 0;
  position: relative; transition: color .2s, background .2s; white-space: nowrap;
}
.stab svg { width: 15px; height: 15px; flex-shrink: 0; }
.stab::after {
  content: ''; position: absolute; bottom: 0; left: 8px; right: 8px;
  height: 2px; background: var(--navy); border-radius: 2px 2px 0 0;
  transform: scaleX(0); transition: transform .25s cubic-bezier(.16,1,.3,1);
}
.stab.on { color: var(--navy); background: var(--white); }
.stab.on::after { transform: scaleX(1); }

.search-body { padding: 1.4rem 1.4rem 1.6rem; background: var(--white); }
.search-panel { display: none; }
.search-panel.on { display: flex; gap: .75rem; align-items: center; animation: fadeIn .25s ease; }
@keyframes fadeIn { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:translateY(0)} }

.search-field {
  flex: 1; display: flex; align-items: center; gap: .65rem;
  background: var(--grey-50); border: 1.5px solid var(--grey-200);
  border-radius: var(--radius-sm); padding: 0 1rem;
  height: 54px; transition: all .2s; cursor: text;
}
.search-field:focus-within { border-color: var(--navy); box-shadow: 0 0 0 3px rgba(11,31,75,.08); background: #fff; }
.search-field svg { color: var(--grey-400); flex-shrink: 0; width: 17px; height: 17px; }
.search-field-inner { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.field-label { font-size: .6rem; font-weight: 700; color: var(--grey-400); letter-spacing: .07em; text-transform: uppercase; line-height: 1; }
.field-input {
  background: none; border: none; outline: none; padding: 0;
  font-family: var(--ff); font-size: .88rem; font-weight: 500;
  color: var(--grey-900); width: 100%; line-height: 1.4;
}
.field-input::placeholder { color: var(--grey-400); font-weight: 400; }
.s-divider { width: 1px; height: 32px; background: var(--grey-200); flex-shrink: 0; }

.search-btn-main {
  height: 54px; padding: 0 2rem;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  color: #fff; border: none; border-radius: var(--radius-sm);
  font-family: var(--ff); font-size: .85rem; font-weight: 700;
  cursor: pointer; white-space: nowrap; transition: all .2s; flex-shrink: 0;
  display: flex; align-items: center; gap: .5rem;
  box-shadow: 0 4px 16px rgba(11,31,75,.3);
}
.search-btn-main:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(11,31,75,.4); }
.search-btn-main svg { width: 15px; height: 15px; }

/* â”€â”€ TRUST MARQUEE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.trust-strip {
  background: var(--white);
  border-top: 1px solid var(--grey-100);
  border-bottom: 1px solid var(--grey-100);
  overflow: hidden;
}
.trust-track-wrap { display: flex; align-items: center; height: 68px; }
.trust-label-fixed {
  flex-shrink: 0; font-size: .6rem; font-weight: 700; color: var(--grey-400);
  text-transform: uppercase; letter-spacing: .14em;
  padding: 0 2rem; border-right: 1px solid var(--grey-100);
  height: 100%; display: flex; align-items: center; white-space: nowrap;
}
.trust-marquee { flex: 1; overflow: hidden; height: 100%; position: relative; }
.trust-track {
  display: flex; align-items: center; height: 100%;
  animation: marquee 30s linear infinite; width: max-content;
}
.trust-track:hover { animation-play-state: paused; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.trust-item {
  display: flex; align-items: center; gap: .9rem;
  padding: 0 2.8rem; border-right: 1px solid var(--grey-100);
  height: 100%; white-space: nowrap;
}

/* â”€â”€ SECTIONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.section     { padding: 4rem 2.5rem; max-width: 1240px; margin: 0 auto; }
.section-sm  { padding: 2.5rem 2.5rem; max-width: 1240px; margin: 0 auto; }
.section-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 1.75rem; gap: 1rem; flex-wrap: wrap;
}
.section-title {
  font-family: var(--ff-display); font-size: 1.9rem; font-weight: 700;
  letter-spacing: .01em; text-transform: uppercase; line-height: 1; color: var(--grey-900);
}
.section-title em {
  font-family: var(--ff-serif); font-style: italic; color: var(--navy);
  font-weight: 400; text-transform: none; font-size: 1.15em; letter-spacing: -.01em;
}
.section-link {
  font-size: .78rem; font-weight: 600; color: var(--navy); text-decoration: none;
  white-space: nowrap; display: flex; align-items: center; gap: .3rem;
}
.section-link:hover { text-decoration: underline; }

/* â”€â”€ CAROUSELS (city / equip / logistics) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.carousel-outer { position:relative; }
.carousel-wrap, .equip-carousel-wrap, .logistics-carousel-wrap {
  overflow-x: auto; overflow-y: hidden; scrollbar-width: none;
  -ms-overflow-style: none; cursor: grab; user-select: none;
}
.carousel-wrap:active, .equip-carousel-wrap:active, .logistics-carousel-wrap:active { cursor: grabbing; }
.carousel-wrap::-webkit-scrollbar, .equip-carousel-wrap::-webkit-scrollbar, .logistics-carousel-wrap::-webkit-scrollbar { display: none; }
.carousel-track, .equip-carousel-track, .logistics-row { display:flex; gap:.85rem; width:max-content; padding-bottom:2px; }
.equip-carousel-track { gap:1rem; }

.carousel-nav  { display:flex; align-items:center; gap:.5rem; }
.carousel-arrow {
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  border:1.5px solid var(--grey-200); background:var(--white);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s; color:var(--grey-600);
}
.carousel-arrow:hover { border-color:var(--navy); color:var(--navy); background:var(--blue-light); }
.carousel-arrow svg { width:15px; height:15px; }

/* City cards */
.city-card {
  border-radius:var(--radius-md); overflow:hidden; background:var(--grey-100);
  cursor:pointer; position:relative; width:190px; flex-shrink:0; aspect-ratio:3/4;
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
  box-shadow:var(--shadow-sm); text-decoration:none; display:block;
}
.city-card:hover { transform:translateY(-5px) scale(1.02); box-shadow:var(--shadow-lg); }
.city-card-bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .6s cubic-bezier(.16,1,.3,1); }
.city-card:hover .city-card-bg { transform:scale(1.07); }
.city-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(11,31,75,.82) 0%,rgba(11,31,75,.12) 55%,transparent 100%); }
.city-card-body { position:absolute; bottom:0; left:0; right:0; padding:1.1rem 1rem 1rem; }
.city-name   { font-family:var(--ff-display); font-size:1.1rem; font-weight:700; color:#fff; line-height:1.1; letter-spacing:.02em; text-transform:uppercase; }
.city-country{ font-size:.7rem; font-weight:500; color:rgba(255,255,255,.65); margin-top:.2rem; }
.city-badge  { position:absolute; top:.75rem; left:.75rem; background:rgba(11,31,75,.75); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.15); border-radius:100px; padding:.22rem .65rem; font-size:.6rem; font-weight:700; color:rgba(255,255,255,.9); text-transform:uppercase; letter-spacing:.07em; }

/* Equipment cards */
.equip-card {
  border-radius:var(--radius-md); overflow:hidden; background:var(--white);
  cursor:pointer; box-shadow:var(--shadow-sm); border:1px solid var(--grey-100);
  text-decoration:none; color:inherit;
  transition:box-shadow .35s, transform .35s cubic-bezier(.16,1,.3,1), border-color .35s;
  display:block; width:280px; flex-shrink:0;
}
.equip-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:var(--grey-200); }
.equip-img { aspect-ratio:16/9; position:relative; overflow:hidden; }
.equip-img-inner { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .55s cubic-bezier(.16,1,.3,1); }
.equip-card:hover .equip-img-inner { transform:scale(1.06); }
.equip-img-overlay { position:absolute; inset:0; background:rgba(11,31,75,.06); }
.equip-body { padding:1.1rem; }
.equip-tag  { display:inline-block; font-family:var(--ff-display); font-size:.62rem; font-weight:700; color:var(--navy); background:var(--blue-light); border-radius:100px; padding:.2rem .6rem; text-transform:uppercase; letter-spacing:.07em; margin-bottom:.5rem; }
.equip-name { font-family:var(--ff); font-size:1rem; font-weight:600; letter-spacing:0; margin-bottom:.32rem; text-transform:none; color:var(--grey-900); line-height:1.35; }
.equip-desc { font-size:.78rem; color:var(--grey-600); line-height:1.55; }
.equip-footer { display:flex; flex-direction:column; align-items:stretch; gap:.55rem; margin-top:.9rem; padding-top:.9rem; border-top:1px solid var(--grey-100); }
.equip-price { font-size:.76rem; font-weight:700; color:var(--grey-500); }
.equip-price span { font-weight:400; color:var(--grey-400); font-size:.72rem; }
.equip-cta  { font-size:.78rem; font-weight:700; color:#fff; text-decoration:none; display:flex; align-items:center; justify-content:center; min-height:40px; border-radius:10px; background:#25d366; box-shadow:0 4px 16px rgba(37,211,102,.22); }
.equip-card:hover .equip-cta { background:#1fba58; }

/* Logistics cards */
.log-card {
  border-radius:var(--radius-md); overflow:hidden; background:var(--white);
  cursor:pointer; text-decoration:none; color:inherit; display:block;
  box-shadow:var(--shadow-sm); border:1px solid var(--grey-100);
  transition:box-shadow .3s, transform .3s;
  opacity:0; transform:translateY(12px); position:relative;
  width:280px; flex-shrink:0;
}
.log-card.revealed { animation:cardIn .55s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes cardIn { to{opacity:1;transform:translateY(0)} }
.log-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); border-color:var(--grey-200); }
.log-photo { aspect-ratio:4/3; position:relative; overflow:hidden; background:var(--grey-100); }
.log-photo-inner { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s cubic-bezier(.16,1,.3,1); }
.log-card:hover .log-photo-inner { transform:scale(1.05); }
.log-photo-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(11,31,75,.6) 0%,transparent 60%); }
.log-photo-label { position:absolute; bottom:.75rem; left:.85rem; font-family:var(--ff-display); font-size:.95rem; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:.03em; }
.log-body { padding:1rem 1rem 1.1rem; }
.log-desc { font-size:.76rem; color:var(--grey-600); line-height:1.6; margin-bottom:.75rem; }
.log-link { font-size:.72rem; font-weight:700; color:var(--navy); display:flex; align-items:center; gap:.25rem; }

/* â”€â”€ STATS ROW â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.stats-row {
  display:grid; grid-template-columns:repeat(4,1fr);
  background:var(--white); border:1px solid var(--grey-100);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); position:relative;
}
.stats-row::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--navy),var(--blue),var(--navy));
}
.stat-block {
  padding:1.4rem 1.5rem; border-right:1px solid var(--grey-100);
  opacity:0; transform:translateY(12px); transition:opacity .6s, transform .6s;
}
.stat-block:last-child { border-right:none; }
.stat-block.visible { opacity:1; transform:translateY(0); }
.stat-num   { font-family:var(--ff-display); font-size:2rem; font-weight:500; line-height:1; color:var(--navy); margin-bottom:.3rem; letter-spacing:-.01em; }
.stat-num sup { font-size:.4em; vertical-align:super; font-weight:600; }
.stat-label { font-size:.72rem; font-weight:400; color:var(--grey-600); line-height:1.4; }

/* â”€â”€ PLATFORM ROWS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.platform-grid { display:flex; flex-direction:column; gap:.75rem; }
.platform-item {
  display:flex; align-items:stretch; border-radius:var(--radius-md); overflow:hidden;
  text-decoration:none; color:inherit; box-shadow:var(--shadow-sm); border:1px solid var(--grey-100);
  height:160px; transition:box-shadow .3s, transform .3s cubic-bezier(.16,1,.3,1); position:relative;
}
.platform-item:hover { box-shadow:var(--shadow-lg); transform:translateY(-2px); }
.platform-img { flex-shrink:0; width:260px; position:relative; overflow:hidden; }
.platform-img-inner { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s cubic-bezier(.16,1,.3,1); }
.platform-item:hover .platform-img-inner { transform:scale(1.05); }
.platform-body { flex:1; padding:1.5rem 1.75rem; display:flex; flex-direction:column; justify-content:center; background:var(--white); }
.platform-tag   { font-family:var(--ff-display); font-size:.6rem; font-weight:700; color:var(--blue); background:var(--blue-light); border-radius:100px; padding:.2rem .6rem; text-transform:uppercase; letter-spacing:.07em; display:inline-block; margin-bottom:.6rem; }
.platform-title { font-family:var(--ff-display); font-size:1.2rem; font-weight:700; text-transform:uppercase; letter-spacing:.02em; color:var(--grey-900); line-height:1.15; margin-bottom:.4rem; }
.platform-desc  { font-size:.8rem; color:var(--grey-600); line-height:1.55; margin-bottom:.85rem; }
.platform-cta   { font-size:.75rem; font-weight:700; color:var(--navy); display:flex; align-items:center; gap:.25rem; }
.platform-num   { flex-shrink:0; width:56px; display:flex; align-items:center; justify-content:center; background:var(--grey-50); border-left:1px solid var(--grey-100); font-family:var(--ff-display); font-size:2.2rem; font-weight:800; color:var(--grey-200); letter-spacing:-.02em; }

/* â”€â”€ ENTERPRISE SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

/* â”€â”€ CTA SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cta-section { background:var(--off-white); border-top:1px solid var(--grey-100); padding:5rem 2.5rem; text-align:center; position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:800px; height:600px; background:radial-gradient(ellipse,rgba(11,31,75,.04) 0%,transparent 70%); pointer-events:none; }
.cta-inner   { position:relative; z-index:1; max-width:640px; margin:0 auto; }
.cta-eyebrow { font-family:var(--ff-display); font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); margin-bottom:1rem; }
.cta-title   { font-family:var(--ff-display); font-size:clamp(2rem,4vw,3.2rem); font-weight:800; color:var(--grey-900); letter-spacing:0em; line-height:.95; text-transform:uppercase; margin-bottom:1rem; }
.cta-title em { font-family:var(--ff-serif); font-style:italic; font-weight:400; color:var(--navy); text-transform:none; font-size:1.1em; }
.cta-sub     { font-size:.95rem; color:var(--grey-600); line-height:1.65; margin-bottom:2.25rem; }
.cta-btns    { display:flex; gap:.85rem; justify-content:center; flex-wrap:wrap; }
.cta-section-home{
  background:linear-gradient(135deg,var(--navy) 0%, var(--blue) 100%);
  border-top:none;
}
.cta-section-home::before{
  background:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(circle at 82% 18%, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 34%);
  width:100%;
  height:100%;
}
.cta-section-home .cta-eyebrow{color:rgba(255,255,255,.78);}
.cta-section-home .cta-title{color:#fff;}
.cta-section-home .cta-title em{color:#dbeafe;}
.cta-section-home .cta-sub{color:rgba(255,255,255,.82);}
.cta-section-home .btn-outline-dark{
  background:#fff;
  color:var(--navy);
  border-color:#fff;
}
.cta-section-home .btn-outline-dark:hover{
  background:rgba(255,255,255,.92);
  color:var(--navy);
  border-color:rgba(255,255,255,.92);
}
.btn-navy-lg     { background:var(--navy); color:#fff; border:none; border-radius:10px; padding:.95rem 2.25rem; font-family:var(--ff); font-size:.9rem; font-weight:700; cursor:pointer; transition:all .2s; box-shadow:0 4px 16px rgba(11,31,75,.28); }
.btn-navy-lg:hover { background:var(--navy-mid); box-shadow:0 8px 28px rgba(11,31,75,.38); transform:translateY(-2px); }
.btn-outline-dark { background:none; color:var(--grey-800); border:1.5px solid var(--grey-200); border-radius:10px; padding:.95rem 2.25rem; font-family:var(--ff); font-size:.9rem; font-weight:600; cursor:pointer; transition:all .2s; }
.btn-outline-dark:hover { border-color:var(--navy); color:var(--navy); }

/* â”€â”€ PAGE HERO (inner pages) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.page-hero {
  position:relative; min-height:460px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  overflow:hidden; padding:5rem 2rem;
  background-size:cover; background-position:center;
}
.page-hero::before {
  content:''; position:absolute; inset:0; z-index:0;
  background:linear-gradient(180deg,rgba(8,18,46,.6) 0%,rgba(8,18,46,.4) 50%,rgba(8,18,46,.65) 100%);
}
.page-hero::after {
  content:''; position:absolute; inset:0; z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  background-repeat:repeat; background-size:128px; pointer-events:none;
}
.page-hero-content { position:relative; z-index:2; text-align:center; max-width:780px; }
.page-hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(255,255,255,.15); color:rgba(255,255,255,.95);
  border:1px solid rgba(255,255,255,.25); backdrop-filter:blur(8px);
  font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:.4rem 1rem; border-radius:100px; margin-bottom:1.5rem;
}
.page-hero-title {
  font-family:var(--ff-display); font-size:clamp(2.5rem,5vw,4.5rem);
  font-weight:800; line-height:.95; letter-spacing:-.01em;
  color:#fff; margin-bottom:1rem; text-transform:uppercase;
  text-shadow:0 2px 24px rgba(0,0,0,.3);
}
.page-hero-title em { font-family:var(--ff-serif); font-style:italic; color:#FFD580; font-weight:400; text-transform:none; }
.page-hero-sub { font-size:1rem; color:rgba(255,255,255,.75); line-height:1.65; max-width:520px; margin:0 auto; }

/* â”€â”€ FILTER BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.filter-bar {
  display:flex; gap:.75rem; align-items:center; flex-wrap:wrap;
  background:var(--white); border:1px solid var(--grey-100);
  border-radius:var(--radius-lg); padding:1.1rem 1.4rem;
  box-shadow:var(--shadow-md); margin-bottom:2rem;
}
.filter-bar select, .filter-bar input {
  height:42px; padding:0 .9rem;
  border:1.5px solid var(--grey-200); border-radius:var(--radius-sm);
  font-family:var(--ff); font-size:.82rem; color:var(--grey-900);
  background:var(--grey-50); outline:none; transition:border-color .2s;
  min-width:0;
}
.filter-bar select:focus, .filter-bar input:focus { border-color:var(--navy); background:#fff; }
.filter-bar input { flex:1; }
.filter-bar select { cursor:pointer; }

/* â”€â”€ LISTING GRID (machinery / products) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.listing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.listing-card {
  border-radius:var(--radius-md); overflow:hidden; background:var(--white);
  border:1px solid var(--grey-100); box-shadow:var(--shadow-sm);
  transition:box-shadow .35s, transform .35s cubic-bezier(.16,1,.3,1);
  text-decoration:none; color:inherit; display:block;
}
.listing-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.listing-card-img { aspect-ratio:16/9; position:relative; overflow:hidden; background:var(--grey-100); }
.listing-card-img-inner { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s cubic-bezier(.16,1,.3,1); }
.listing-card:hover .listing-card-img-inner { transform:scale(1.05); }
.listing-card-body { padding:1.1rem; }
.listing-tag { display:inline-block; font-family:var(--ff-display); font-size:.6rem; font-weight:700; color:var(--navy); background:var(--blue-light); border-radius:100px; padding:.2rem .6rem; text-transform:uppercase; letter-spacing:.07em; margin-bottom:.5rem; }
.listing-tag.green { color:#166534; background:#dcfce7; }
.listing-tag.gold  { color:#854d0e; background:#fef9c3; }
.listing-name  { font-family:var(--ff-display); font-size:1.1rem; font-weight:700; text-transform:uppercase; letter-spacing:.02em; color:var(--grey-900); margin-bottom:.35rem; line-height:1.15; }
.listing-price { font-size:.88rem; font-weight:700; color:var(--grey-900); margin-bottom:.5rem; }
.listing-price span { font-weight:400; color:var(--grey-400); font-size:.75rem; }
.listing-meta  { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:.85rem; }
.listing-chip  { font-size:.65rem; font-weight:600; color:var(--grey-600); background:var(--grey-100); border-radius:100px; padding:.2rem .55rem; }
.listing-footer{ display:flex; gap:.6rem; }
.btn-sm-navy   { height:34px; padding:0 1rem; background:var(--navy); color:#fff; border:none; border-radius:var(--radius-sm); font-family:var(--ff); font-size:.75rem; font-weight:700; cursor:pointer; transition:all .2s; flex:1; display:flex; align-items:center; justify-content:center; }
.btn-sm-navy:hover { background:var(--navy-mid); }
.btn-sm-outline{ height:34px; padding:0 1rem; background:none; color:var(--navy); border:1.5px solid var(--grey-200); border-radius:var(--radius-sm); font-family:var(--ff); font-size:.75rem; font-weight:600; cursor:pointer; transition:all .2s; display:flex; align-items:center; justify-content:center; }
.btn-sm-outline:hover { border-color:var(--navy); }

/* â”€â”€ TRAVEL CARDS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.travel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.trip-card {
  border-radius:var(--radius-md); overflow:hidden; background:var(--white);
  border:1px solid var(--grey-100); box-shadow:var(--shadow-sm);
  transition:box-shadow .35s, transform .35s; text-decoration:none; color:inherit;
}
.trip-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.trip-card-img { aspect-ratio:4/3; position:relative; overflow:hidden; }
.trip-card-img-inner { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .6s cubic-bezier(.16,1,.3,1); }
.trip-card:hover .trip-card-img-inner { transform:scale(1.06); }
.trip-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(11,31,75,.72) 0%,transparent 55%); }
.trip-card-label { position:absolute; bottom:1rem; left:1rem; right:1rem; }
.trip-card-label .city-name { font-size:1.3rem; }
.trip-card-body { padding:1rem 1.1rem 1.2rem; }
.trip-name  { font-family:var(--ff-display); font-size:1.05rem; font-weight:700; text-transform:uppercase; color:var(--grey-900); margin-bottom:.35rem; }
.trip-price { font-size:.85rem; font-weight:700; color:var(--navy); margin-bottom:.5rem; }
.trip-meta  { display:flex; gap:.4rem; flex-wrap:wrap; }

/* â”€â”€ FORMS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-panel {
  background:var(--white); border:1px solid var(--grey-100);
  border-radius:var(--radius-xl); box-shadow:var(--shadow-md); padding:2rem;
}
.form-panel h3 { font-family:var(--ff-display); font-size:1.4rem; font-weight:700; text-transform:uppercase; color:var(--grey-900); margin-bottom:.35rem; }
.form-panel p  { font-size:.82rem; color:var(--grey-600); line-height:1.6; margin-bottom:1.5rem; }
.form-grid { display:grid; gap:.85rem; }
.form-grid.two { grid-template-columns:1fr 1fr; }
.form-group { display:flex; flex-direction:column; gap:.35rem; }
.form-label { font-size:.62rem; font-weight:700; color:var(--grey-400); letter-spacing:.07em; text-transform:uppercase; }
.form-input, .form-select, .form-textarea {
  width:100%; height:46px; padding:0 1rem;
  border:1.5px solid var(--grey-200); border-radius:var(--radius-sm);
  font-family:var(--ff); font-size:.85rem; color:var(--grey-900);
  background:var(--grey-50); outline:none; transition:all .2s; appearance:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--navy); background:#fff; box-shadow:0 0 0 3px rgba(11,31,75,.07); }
.form-textarea { height:auto; min-height:96px; padding:.75rem 1rem; resize:vertical; }
.form-span2 { grid-column:1/-1; }

/* â”€â”€ ADMIN â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.admin-layout { display:grid; grid-template-columns:240px 1fr; min-height:calc(100vh - 64px); }
.admin-sidebar { background:var(--white); border-right:1px solid var(--grey-100); padding:1.5rem 1rem; position:sticky; top:64px; align-self:start; height:calc(100vh - 64px); overflow-y:auto; }
.sidebar-section { margin-bottom:1.5rem; }
.sidebar-label  { font-size:.6rem; font-weight:700; color:var(--grey-400); letter-spacing:.12em; text-transform:uppercase; padding:.4rem .75rem; margin-bottom:.35rem; }
.sidebar-link   { display:flex; align-items:center; gap:.6rem; padding:.6rem .75rem; border-radius:8px; font-size:.83rem; font-weight:500; color:var(--grey-600); text-decoration:none; transition:all .15s; margin-bottom:.15rem; }
.sidebar-link:hover   { background:var(--grey-50); color:var(--grey-900); }
.sidebar-link.active  { background:var(--blue-light); color:var(--navy); font-weight:600; }
.admin-main { padding:2rem 2.5rem; background:var(--grey-50); }
.admin-main-header { margin-bottom:1.75rem; }
.admin-main-header h1 { font-family:var(--ff-display); font-size:1.8rem; font-weight:700; text-transform:uppercase; color:var(--grey-900); }
.admin-main-header p  { font-size:.82rem; color:var(--grey-600); margin-top:.25rem; }

.metrics-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:1.5rem; }
.metric-card { background:var(--white); border:1px solid var(--grey-100); border-radius:var(--radius-md); padding:1.25rem 1.5rem; box-shadow:var(--shadow-sm); }
.metric-label { font-size:.62rem; font-weight:700; color:var(--grey-400); letter-spacing:.07em; text-transform:uppercase; margin-bottom:.5rem; }
.metric-value { font-family:var(--ff-display); font-size:1.75rem; font-weight:700; color:var(--grey-900); line-height:1; margin-bottom:.3rem; }
.metric-trend { font-size:.72rem; font-weight:600; }
.trend-up { color:#15803d; } .trend-dn { color:#dc2626; }

.table-card { background:var(--white); border:1px solid var(--grey-100); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); }
.table-card-head { padding:1rem 1.5rem; border-bottom:1px solid var(--grey-100); display:flex; justify-content:space-between; align-items:center; }
.table-card-head h3 { font-family:var(--ff-display); font-size:1rem; font-weight:700; text-transform:uppercase; color:var(--grey-900); }
table.data-table { width:100%; border-collapse:collapse; }
table.data-table th { background:var(--grey-50); padding:.75rem 1.25rem; text-align:left; font-size:.62rem; font-weight:700; color:var(--grey-400); letter-spacing:.07em; text-transform:uppercase; border-bottom:1px solid var(--grey-100); }
table.data-table td { padding:.9rem 1.25rem; border-bottom:1px solid var(--grey-100); font-size:.82rem; color:var(--grey-900); }
table.data-table tr:last-child td { border-bottom:none; }
table.data-table tr:hover td { background:var(--grey-50); }
.badge { display:inline-flex; align-items:center; padding:.22rem .65rem; border-radius:100px; font-size:.65rem; font-weight:700; letter-spacing:.04em; }
.badge-green  { background:#dcfce7; color:#15803d; }
.badge-yellow { background:#fef9c3; color:#854d0e; }
.badge-blue   { background:#dbeafe; color:#1d4ed8; }
.badge-grey   { background:var(--grey-100); color:var(--grey-600); }

/* â”€â”€ USER DASHBOARD â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.user-sidebar-head { display:flex; align-items:center; gap:.9rem; margin-bottom:1.5rem; padding:.4rem .75rem 1rem; border-bottom:1px solid var(--grey-100); }
.user-avatar { width:46px; height:46px; border-radius:14px; display:grid; place-items:center; background:linear-gradient(135deg, var(--navy), var(--blue)); color:#fff; font-family:var(--ff-display); font-size:1rem; font-weight:800; }
.user-sidebar-name { font-family:var(--ff-display); font-size:1rem; font-weight:700; text-transform:uppercase; color:var(--grey-900); }
.user-sidebar-sub { font-size:.74rem; color:var(--grey-500); margin-top:.15rem; }
.user-sidebar-card { background:linear-gradient(180deg, #f8fbff, #eef5ff); border:1px solid #d9e8ff; border-radius:16px; padding:1rem; margin-top:1rem; }
.user-main-header { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; }
.user-main-header p { max-width:720px; }
.user-badge { margin-bottom:.85rem; }
.user-header-actions { display:flex; gap:.75rem; flex-wrap:wrap; }
.user-dashboard-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:1rem; margin-bottom:1rem; }
.user-hero-body { padding:1.25rem 1.5rem 1.5rem; }
.user-stat-stack { display:grid; grid-template-columns:repeat(3,1fr); gap:.85rem; margin-bottom:1rem; }
.user-stat-chip { background:var(--grey-50); border:1px solid var(--grey-100); border-radius:14px; padding:.9rem 1rem; }
.user-stat-chip span { display:block; font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--grey-400); margin-bottom:.35rem; }
.user-stat-chip strong { font-family:var(--ff-display); font-size:1.15rem; font-weight:700; color:var(--grey-900); }
.user-feature-grid, .user-recommend-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
.user-action-card, .user-recommend-card { display:block; text-decoration:none; color:inherit; background:var(--white); border:1px solid var(--grey-100); border-radius:16px; padding:1rem 1.05rem; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s, border-color .2s; }
.user-action-card:hover, .user-recommend-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:#cfe0ff; }
.user-action-title { font-family:var(--ff-display); font-size:1.05rem; font-weight:700; text-transform:uppercase; color:var(--grey-900); margin:.2rem 0 .45rem; }
.user-action-card p, .user-recommend-card p, .user-activity-body p, .user-timeline-item p { font-size:.82rem; line-height:1.6; color:var(--grey-600); }
.user-activity-list { padding:1rem 1.5rem 1.25rem; }
.user-activity-item { display:grid; grid-template-columns:88px 1fr; gap:1rem; padding:.95rem 0; border-bottom:1px solid var(--grey-100); }
.user-activity-item:last-child { border-bottom:none; }
.user-activity-date { font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--grey-400); padding-top:.2rem; }
.user-activity-top { display:flex; justify-content:space-between; align-items:center; gap:.75rem; margin-bottom:.35rem; }
.user-tracking-card { padding:1.1rem 1.5rem 1.4rem; }
.user-tracking-top { display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; margin-bottom:.35rem; }
.user-tracking-meta { font-size:.8rem; color:var(--grey-500); margin-bottom:1rem; }
.user-timeline { display:grid; gap:.9rem; }
.user-timeline-item { display:grid; grid-template-columns:14px 1fr; gap:.85rem; }
.user-timeline-dot { width:14px; height:14px; border-radius:50%; margin-top:.25rem; background:var(--grey-200); box-shadow:0 0 0 4px var(--grey-50); }
.user-timeline-dot.completed { background:#22c55e; }
.user-timeline-dot.active { background:#2563eb; }
.user-timeline-dot.upcoming { background:#f59e0b; }
.user-timeline-time { font-size:.72rem; color:var(--grey-400); margin:.2rem 0; }

/* â”€â”€ BLOG â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.blog-card {
  border-radius:var(--radius-md); overflow:hidden; background:var(--white);
  border:1px solid var(--grey-100); box-shadow:var(--shadow-sm);
  transition:box-shadow .35s, transform .35s; text-decoration:none; color:inherit; display:block;
}
.blog-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.blog-card-img { aspect-ratio:16/9; position:relative; overflow:hidden; background:var(--grey-100); }
.blog-card-img-inner { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s cubic-bezier(.16,1,.3,1); }
.blog-card:hover .blog-card-img-inner { transform:scale(1.05); }
.blog-card-body { padding:1.1rem; }
.blog-cat  { font-family:var(--ff-display); font-size:.6rem; font-weight:700; color:var(--blue); background:var(--blue-light); border-radius:100px; padding:.2rem .6rem; text-transform:uppercase; letter-spacing:.07em; display:inline-block; margin-bottom:.6rem; }
.blog-title{ font-family:var(--ff-display); font-size:1.05rem; font-weight:700; text-transform:uppercase; letter-spacing:.01em; color:var(--grey-900); line-height:1.2; margin-bottom:.4rem; }
.blog-excerpt { font-size:.76rem; color:var(--grey-600); line-height:1.6; margin-bottom:.8rem; }
.blog-meta { font-size:.68rem; color:var(--grey-400); display:flex; align-items:center; gap:.5rem; }

/* â”€â”€ TRACKING â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.track-input-row { display:flex; gap:.75rem; max-width:600px; margin:1.5rem 0; }
.track-input { flex:1; height:52px; padding:0 1.25rem; border:1.5px solid rgba(255,255,255,.2); border-radius:var(--radius-sm); background:rgba(255,255,255,.1); color:#fff; font-family:var(--ff); font-size:.9rem; font-weight:500; outline:none; letter-spacing:.06em; transition:border-color .2s; }
.track-input::placeholder { color:rgba(255,255,255,.4); font-weight:400; }
.track-input:focus { border-color:rgba(255,255,255,.5); }

.timeline { padding:0; position:relative; }
.timeline::before { content:''; position:absolute; left:11px; top:8px; bottom:8px; width:2px; background:linear-gradient(to bottom,var(--navy),var(--grey-200)); }
.tl-item { position:relative; padding:.75rem 0 1.5rem 2.5rem; }
.tl-dot { position:absolute; left:0; top:8px; width:24px; height:24px; border-radius:50%; border:2px solid var(--grey-200); background:var(--white); display:flex; align-items:center; justify-content:center; z-index:1; }
.tl-dot.done { border-color:var(--navy); background:var(--navy); }
.tl-dot.done::after { content:''; width:8px; height:8px; border-radius:50%; background:#fff; }
.tl-dot.active { border-color:var(--blue); background:var(--blue-light); box-shadow:0 0 0 4px rgba(24,71,200,.12); }
.tl-dot.active::after { content:''; width:8px; height:8px; border-radius:50%; background:var(--blue); }
.tl-time  { font-size:.65rem; font-weight:600; color:var(--grey-400); letter-spacing:.04em; margin-bottom:.2rem; }
.tl-title { font-family:var(--ff-display); font-size:1rem; font-weight:700; text-transform:uppercase; letter-spacing:.02em; color:var(--grey-900); margin-bottom:.2rem; }
.tl-desc  { font-size:.78rem; color:var(--grey-600); line-height:1.55; }

/* â”€â”€ INSTALL â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.install-wrap { max-width:760px; margin:0 auto; padding:3rem 2rem 4rem; }
.install-step { background:var(--white); border:1px solid var(--grey-100); border-radius:var(--radius-xl); padding:2rem; margin-bottom:1rem; box-shadow:var(--shadow-sm); }
.install-step-head { display:flex; align-items:center; gap:.75rem; margin-bottom:1rem; }
.install-step-num  { width:32px; height:32px; border-radius:50%; background:var(--navy); color:#fff; font-family:var(--ff-display); font-size:1rem; font-weight:800; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.install-step h3   { font-family:var(--ff-display); font-size:1.1rem; font-weight:700; text-transform:uppercase; letter-spacing:.02em; color:var(--grey-900); }
.code-block { background:var(--grey-900); border-radius:var(--radius-sm); padding:1rem 1.25rem; font-family:'Courier New',monospace; font-size:.8rem; color:#93c5fd; overflow-x:auto; margin:.75rem 0; }
.code-comment { color:rgba(147,197,253,.45); }

/* â”€â”€ SCROLL REVEAL â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .65s ease, transform .65s cubic-bezier(.16,1,.3,1); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* â”€â”€ RESPONSIVE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:900px) {
  .listing-grid, .travel-grid, .blog-grid { grid-template-columns:1fr 1fr; }
  .metrics-grid { grid-template-columns:1fr 1fr; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .stat-block:nth-child(2) { border-right:none; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .platform-img { width:200px; }
  nav { padding:0 1.5rem; }
  .nav-links, .nav-actions { display:none; }
  .nav-mobile-tools { display:flex; }
  .nav-cart-btn-mobile, .nav-hamburger { display:flex; }
  .nav-hamburger { display:flex; }
  .admin-layout { grid-template-columns:1fr; }
  .admin-sidebar { position:static; height:auto; border-right:none; border-bottom:1px solid var(--grey-100); padding:1rem 1.5rem; }
  .user-dashboard-grid { grid-template-columns:1fr; }
  .user-main-header { flex-direction:column; }
  .user-stat-stack, .user-feature-grid, .user-recommend-grid { grid-template-columns:1fr 1fr; }
}
@media (min-width:901px) {
  .nav-mobile-tools,
  .nav-cart-btn-mobile {
    display: none !important;
  }
}
@media (max-width:600px) {
  input,
  select,
  textarea,
  button {
    font-size: 16px !important;
  }
  nav { padding:0 1rem; gap:.55rem; height:64px; }
  .nav-mobile-tools { gap:.42rem; }
  .nav-cart-btn,
  .nav-cart-btn-mobile { width:34px; height:34px; border-radius:9px; }
  .nav-cart-btn-mobile svg { width:16px; height:16px; }
  .cart-badge { top:-4px; right:-4px; min-width:14px; height:14px; font-size:.54rem; border-width:1.5px; padding:0 3px; }
  .nav-hamburger { padding:4px; }
  .nav-hamburger span { width:20px; }
  .mobile-nav { top:64px; }
  body { overflow-x: hidden; }
  .hero {
    min-height: auto;
    padding: 4.85rem .85rem 2.2rem;
    align-items: center;
  }
  .hero-content {
    width: min(100%, 372px);
    max-width: 372px;
    padding: 0;
    margin: 0 auto;
    text-align: center;
  }
  .hero-badge {
    width: 100%;
    max-width: 100%;
    justify-content: center;
    padding: .46rem .78rem;
    margin: 0 auto .95rem;
    font-size: .6rem;
    letter-spacing: .1em;
    line-height: 1.3;
    white-space: normal;
    text-align: center;
  }
  .hero-title {
    width: 100%;
    max-width: 10.6ch;
    margin: 0 auto .78rem;
    font-size: clamp(2.22rem, 11.8vw, 3.15rem);
    line-height: .9;
    letter-spacing: -.01em;
  }
  .hero-sub {
    width: 100%;
    max-width: 34ch;
    font-size: .84rem;
    line-height: 1.55;
    margin: 0 auto 1.1rem;
  }
  .search-card {
    width: 100%;
    max-width: 372px;
    margin: 0 auto;
    border-radius: 24px;
    overflow: hidden;
  }
  .search-tabs {
    padding: .78rem .72rem 0;
    gap: .38rem;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: visible;
  }
  .stab {
    min-width: 0;
    width: 100%;
    justify-content: center;
    text-align: center;
    padding: .62rem .4rem .72rem;
    font-size: .68rem;
    line-height: 1.2;
    white-space: normal;
  }
  .search-body {
    padding: .88rem .82rem .9rem;
  }
  .page-hero { min-height:360px; padding:3rem 1.25rem; }
  .search-panel,
  .search-panel.on {
    width: 100%;
    min-width: 0;
    flex-wrap: wrap;
    gap: .62rem;
  }
  .s-divider { display:none; }
  .search-panel.on > .search-field,
  .search-panel.on > .search-btn-main {
    flex: 1 1 100% !important;
    width: 100% !important;
    max-width: 100%;
  }
  .search-field { height:46px; width:100%; min-width:0; padding:0 .82rem; }
  .search-field-inner { min-width:0; width:100%; }
  .field-input { min-width:0; font-size:.8rem; }
  .field-label { font-size:.54rem; }
  .search-btn-main { height:44px; width:100%; min-width:0; justify-content:center; font-size:.78rem; }
  .listing-grid, .travel-grid, .blog-grid, .metrics-grid { grid-template-columns:1fr; }
  .platform-item { flex-direction:column; height:auto; }
  .platform-img { width:100%; height:160px; }
  .platform-img-inner { position:relative; height:160px; width:100%; }
  .platform-num { display:none; }
  .footer-grid { grid-template-columns:1fr; gap:1.75rem; }
  .section, .section-sm { padding:2.5rem 1.25rem; }
  .cta-section { padding:2rem 1.25rem; }
  .form-grid.two { grid-template-columns:1fr; }
  .carousel-track, .equip-carousel-track, .logistics-row { gap:.55rem; }
  .equip-carousel-track { gap:.65rem; }
  .city-card { width:118px; }
  .city-card { aspect-ratio:3/3.55; }
  .city-card-body { padding:.72rem .68rem .68rem; }
  .city-name { font-size:.84rem; line-height:1.04; }
  .city-country { font-size:.58rem; margin-top:.12rem; }
  .city-badge { top:.5rem; left:.5rem; padding:.16rem .46rem; font-size:.5rem; }
  .equip-card { width:176px; }
  .equip-img { aspect-ratio:16/7.6; }
  .equip-body { padding:.74rem; }
  .equip-tag { font-size:.5rem; padding:.14rem .42rem; margin-bottom:.32rem; }
  .equip-name { font-size:.78rem; margin-bottom:.18rem; line-height:1.28; }
  .equip-desc { font-size:.63rem; line-height:1.34; }
  .equip-footer { gap:.32rem; margin-top:.5rem; padding-top:.5rem; }
  .equip-price { font-size:.62rem; }
  .log-card { width:186px; }
  .log-photo { aspect-ratio:4/2.55; }
  .log-photo-label { bottom:.52rem; left:.62rem; font-size:.72rem; }
  .log-body { padding:.72rem .72rem .8rem; }
  .log-desc { font-size:.64rem; line-height:1.38; margin-bottom:.45rem; }
  .log-link { font-size:.62rem; }
  .user-stat-stack, .user-feature-grid, .user-recommend-grid { grid-template-columns:1fr; }
  .user-activity-item { grid-template-columns:1fr; gap:.35rem; }
  .user-tracking-top, .user-activity-top { flex-direction:column; align-items:flex-start; }
}
@media (max-width:400px) {
  input,
  select,
  textarea,
  button {
    font-size: 16px !important;
  }
  .hero {
    padding: 4.5rem .68rem 1.95rem;
  }
  .hero-content {
    width: min(100%, 336px);
    max-width: 336px;
    padding: 0;
  }
  .hero-badge {
    font-size: .56rem;
    padding: .42rem .66rem;
    margin-bottom: .82rem;
  }
  .hero-title {
    max-width: 10.1ch;
    font-size: clamp(2rem, 10.9vw, 2.7rem);
    line-height: .91;
  }
  .hero-sub {
    max-width: 32ch;
    font-size: .79rem;
    line-height: 1.52;
    margin-bottom: .98rem;
  }
  .search-card {
    max-width: 336px;
    border-radius: 22px;
  }
  .search-tabs {
    padding: .72rem .64rem 0;
    gap: .34rem;
  }
  .stab {
    padding: .56rem .32rem .66rem;
    font-size: .63rem;
  }
  .search-body {
    padding: .8rem .72rem .82rem;
  }
  .search-field {
    height: 44px;
    padding: 0 .72rem;
  }
  .field-label {
    font-size: .5rem;
  }
  .field-input {
    font-size: .76rem;
  }
  .search-btn-main {
    height: 42px;
    font-size: .74rem;
  }
  .stats-row { grid-template-columns:1fr 1fr; }
}

/* â”€â”€ FOOTER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
footer { background:#0a0f1e; padding:4rem 2.5rem 2rem; }
.footer-grid { max-width:1240px; margin:0 auto; display:grid; grid-template-columns:1.6fr minmax(0,2fr); gap:3.5rem; margin-bottom:3rem; }
.footer-links-wrap { display:grid; grid-template-columns:1fr 1fr; gap:3rem; min-width:0; }
.footer-brand { font-family:var(--ff-display); font-weight:800; font-size:1.35rem; color:#fff; letter-spacing:.04em; margin-bottom:.7rem; display:flex; align-items:baseline; gap:.2em; }
.footer-brand-image { display:block; height:32px; width:auto; max-width:230px; object-fit:contain; }
.footer-brand-ltd { font-size:.5em; font-weight:600; color:rgba(255,255,255,.55); letter-spacing:.08em; }
.footer-tagline { font-size:.82rem; color:rgba(255,255,255,.65); line-height:1.65; max-width:220px; }
.footer-divider { width:32px; height:2px; background:var(--blue); margin:1.1rem 0; border-radius:2px; opacity:.6; }
.footer-col h4 { font-family:var(--ff-display); font-size:.7rem; font-weight:700; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.12em; margin-bottom:1.1rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.55rem; }
.footer-col a  { font-size:.82rem; color:rgba(255,255,255,.72); text-decoration:none; transition:color .2s; }
.footer-col a:hover { color:#fff; }
.footer-col a.footer-contact-link { white-space: nowrap !important; overflow-wrap: normal !important; word-break: normal !important; }
.footer-bottom { max-width:1240px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; padding-top:2rem; border-top:1px solid rgba(255,255,255,.1); font-size:.72rem; color:rgba(255,255,255,.45); flex-wrap:wrap; gap:.5rem; }
.footer-cities { display:flex; gap:1.5rem; }

@media (max-width: 1024px) {
  footer {
    padding: 3rem 1.25rem 1.5rem !important;
    overflow: hidden !important;
  }
  .footer-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 1.5rem !important;
    margin-bottom: 2rem !important;
  }
  .footer-grid > * {
    min-width: 0 !important;
  }
  .footer-grid > div {
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .footer-col {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
  }
  .footer-grid > div:first-child {
    grid-column: 1 / -1 !important;
  }
  .footer-grid > .footer-col:last-child {
    grid-column: 1 / -1 !important;
  }
  .footer-tagline {
    max-width: none !important;
    font-size: .95rem !important;
  }
    .footer-brand {
      font-size: 1.2rem !important;
      flex-wrap: wrap !important;
    }
    .nav-logo-image { height:26px !important; max-width:176px !important; }
    .footer-brand-image { height:26px !important; max-width:176px !important; }
  .footer-divider {
    margin: .8rem 0 1rem !important;
  }
  .footer-col h4 {
    margin-bottom: .8rem !important;
  }
  .footer-col ul {
    gap: .45rem !important;
    min-width: 0 !important;
  }
  .footer-col li {
    min-width: 0 !important;
    width: 100% !important;
  }
  .footer-col a {
    display: block !important;
    font-size: .95rem !important;
    line-height: 1.5 !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }
  .footer-bottom {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: .9rem !important;
    padding-top: 1.4rem !important;
  }
  .footer-bottom > * {
    width: 100% !important;
    min-width: 0 !important;
  }
  .footer-cities {
    flex-wrap: wrap !important;
    gap: .75rem 1.1rem !important;
  }
}
@media (max-width: 560px) {
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
  .footer-grid > div:first-child {
    grid-column: auto !important;
  }
  .footer-links-wrap {
    grid-template-columns: minmax(0,.88fr) minmax(0,1.12fr) !important;
    gap: .9rem !important;
    grid-column: auto !important;
  }
  .footer-col h4 {
    margin-bottom: .68rem !important;
  }
  .footer-col a {
    font-size: .88rem !important;
    line-height: 1.42 !important;
  }
  .footer-col a.footer-contact-link {
    font-size: .82rem !important;
    letter-spacing: -.01em;
  }
  .footer-col ul {
    gap: .38rem !important;
  }
}

@media (max-width: 820px) {
  .home-platforms .section-header {
    flex-direction: column;
    align-items: flex-start;
    gap: .65rem;
  }
  .home-platforms .section-link {
    font-size: .85rem;
  }
  .home-platforms .platform-grid {
    gap: .9rem;
  }
  .home-platforms .platform-item {
    flex-direction: row;
    height: 138px;
    border-radius: 16px;
  }
  .home-platforms .platform-img {
    width: 42%;
    min-width: 42%;
    height: auto;
  }
  .home-platforms .platform-img-inner {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
  .home-platforms .platform-body {
    padding: .95rem .95rem .9rem;
  }
  .home-platforms .platform-tag {
    font-size: .52rem;
    margin-bottom: .4rem;
  }
  .home-platforms .platform-title {
    font-size: .92rem;
    margin-bottom: .25rem;
  }
  .home-platforms .platform-desc {
    font-size: .74rem;
    line-height: 1.45;
    margin-bottom: .45rem;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }
  .home-platforms .platform-cta {
    font-size: .72rem;
  }
  .home-platforms .platform-num {
    display: none;
  }
}

@media (max-width: 560px) {
  .home-platforms .platform-item {
    height: 124px;
  }
  .home-platforms .platform-img {
    width: 40%;
    min-width: 40%;
  }
  .home-platforms .platform-body {
    padding: .8rem .82rem;
  }
  .home-platforms .platform-title {
    font-size: .84rem;
  }
  .home-platforms .platform-desc {
    font-size: .7rem;
  }
  .home-platforms .platform-cta {
    font-size: .68rem;
  }
}

/* â”€â”€ AUTH-AWARE NAV ADDITIONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.nav-cart-btn { position:relative; display:flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:10px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.82); text-decoration:none; transition:background .2s,border-color .2s,color .2s; cursor:pointer; }
.nav-cart-btn-mobile { display: none; }
.nav-cart-btn:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.18); color:#fff; }
.cart-badge { position:absolute; top:-6px; right:-6px; background:#ef4444; color:#fff; font-size:.6rem; font-weight:700; min-width:16px; height:16px; border-radius:999px; display:flex; align-items:center; justify-content:center; padding:0 4px; line-height:1; border:2px solid #fff; }
.nav-user-wrap { position:relative; }
.nav-user-btn { display:flex; align-items:center; gap:.4rem; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.84); border-radius:99px; padding:.35rem .75rem .35rem .45rem; cursor:pointer; font-size:.82rem; font-weight:600; transition:background .2s,border-color .2s,color .2s; }
.nav-user-btn:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.18); color:#fff; }
.nav-user-initials { width:26px; height:26px; border-radius:50%; background:var(--blue); color:#fff; font-size:.7rem; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.nav-user-menu { position:absolute; top:calc(100% + 10px); right:0; min-width:200px; background:#fff; border-radius:12px; box-shadow:0 8px 32px rgba(0,0,0,.16); padding:.5rem; z-index:9999; display:none; }
.nav-user-menu.open { display:block; animation:fadeSlideDown .15s ease; }
@keyframes fadeSlideDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.nav-user-info { padding:.6rem .75rem .5rem; border-bottom:1px solid #f1f5f9; margin-bottom:.25rem; }
.nav-user-info strong { display:block; font-size:.85rem; color:#1e293b; }
.nav-user-info span { font-size:.72rem; color:#94a3b8; }
.nav-user-menu a { display:block; padding:.5rem .75rem; font-size:.83rem; color:#374151; text-decoration:none; border-radius:7px; transition:background .15s; }
.nav-user-menu a:hover { background:#f8fafc; color:#0f172a; }
.nav-user-divider { border:none; border-top:1px solid #f1f5f9; margin:.3rem 0; }
.nav-logout { color:#dc2626 !important; }
.nav-logout:hover { background:#fef2f2 !important; }

/* â”€â”€ WHATSAPP FLOAT â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.wa-float { position:fixed; bottom:1.75rem; right:1.75rem; z-index:9000; width:54px; height:54px; border-radius:50%; background:#25d366; color:#fff; display:flex; align-items:center; justify-content:center; text-decoration:none; box-shadow:0 4px 18px rgba(37,211,102,.45); transition:transform .2s,box-shadow .2s; }
.wa-float:hover { transform:translateY(-3px) scale(1.07); box-shadow:0 8px 28px rgba(37,211,102,.55); }
@media (max-width: 720px) {
  .wa-float {
    width: 46px;
    height: 46px;
    right: 1rem;
    bottom: 1rem;
    box-shadow: 0 4px 14px rgba(37,211,102,.32);
  }
  .wa-float svg {
    width: 20px;
    height: 20px;
  }
}
@media (max-width: 420px) {
  .wa-float {
    width: 42px;
    height: 42px;
    right: .85rem;
    bottom: .85rem;
    box-shadow: 0 3px 12px rgba(37,211,102,.28);
  }
  .wa-float svg {
    width: 18px;
    height: 18px;
  }
}

/* â”€â”€ PRODUCT / LISTING CARDS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.product-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:1.5rem; }
.product-card { background:#fff; border-radius:14px; box-shadow:0 2px 12px rgba(0,0,0,.06); overflow:hidden; display:flex; flex-direction:column; transition:transform .2s,box-shadow .2s; }
.product-card:hover { transform:translateY(-3px); box-shadow:0 8px 28px rgba(0,0,0,.12); }
.product-card-img { aspect-ratio:4/3; background:#f1f5f9; overflow:hidden; position:relative; }
.product-card-img img { width:100%; height:100%; object-fit:cover; }
.product-card-promoted { position:absolute; top:.6rem; left:.6rem; background:var(--blue); color:#fff; font-size:.65rem; font-weight:700; padding:.2rem .6rem; border-radius:99px; text-transform:uppercase; letter-spacing:.06em; }
.product-card-body { padding:1.1rem 1.2rem; flex:1; display:flex; flex-direction:column; gap:.35rem; }
.product-card-title { font-size:.95rem; font-weight:700; color:#1e293b; line-height:1.35; }
.product-card-meta { font-size:.75rem; color:#94a3b8; }
.product-card-price { font-size:1.1rem; font-weight:800; color:#0f172a; margin-top:auto; padding-top:.5rem; }
.product-card-price span { font-size:.72rem; font-weight:500; color:#94a3b8; margin-left:.2rem; }
.product-card-actions { display:flex; gap:.5rem; padding:.9rem 1.2rem; border-top:1px solid #f1f5f9; }
.btn-add-cart { flex:1; background:#25d366; color:#fff; border:none; border-radius:8px; padding:.55rem .75rem; font-size:.82rem; font-weight:700; cursor:pointer; transition:background .2s, transform .2s, box-shadow .2s; box-shadow:0 4px 16px rgba(37,211,102,.24); }
.btn-add-cart:hover { background:#1fba58; transform:translateY(-1px); box-shadow:0 8px 20px rgba(37,211,102,.3); }
.btn-view-listing { flex:1; background:#f8fafc; color:#374151; border:1.5px solid #e2e8f0; border-radius:8px; padding:.55rem .75rem; font-size:.82rem; font-weight:600; text-decoration:none; text-align:center; transition:background .2s; }
.btn-view-listing:hover { background:#f1f5f9; }

/* â”€â”€ CART PAGE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cart-wrap { max-width:1000px; margin:6rem auto 4rem; padding:0 1.5rem; }
.cart-title { font-size:1.6rem; font-weight:800; color:#0f172a; margin-bottom:1.5rem; }
.cart-layout { display:grid; grid-template-columns:1fr 320px; gap:2rem; align-items:start; }
.cart-items { display:flex; flex-direction:column; gap:1rem; }
.cart-item { display:flex; gap:1.25rem; background:#fff; border-radius:14px; padding:1.1rem 1.2rem; box-shadow:0 2px 12px rgba(0,0,0,.06); align-items:center; }
.cart-item-img { width:80px; height:72px; border-radius:9px; object-fit:cover; background:#f1f5f9; flex-shrink:0; }
.cart-item-info { flex:1; min-width:0; }
.cart-item-name { font-size:.92rem; font-weight:700; color:#1e293b; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cart-item-meta { font-size:.75rem; color:#94a3b8; margin-top:.15rem; }
.cart-item-price { font-size:.92rem; font-weight:700; color:#0f172a; white-space:nowrap; }
.cart-qty-ctrl { display:flex; align-items:center; gap:.5rem; }
.cart-qty-ctrl button { width:28px; height:28px; border-radius:7px; border:1.5px solid #e2e8f0; background:#f8fafc; color:#374151; font-size:1rem; line-height:1; cursor:pointer; transition:background .15s; }
.cart-qty-ctrl button:hover { background:#e2e8f0; }
.cart-qty-ctrl span { min-width:24px; text-align:center; font-weight:700; font-size:.88rem; }
.cart-remove { background:none; border:none; color:#94a3b8; cursor:pointer; font-size:.8rem; margin-left:.5rem; transition:color .15s; }
.cart-remove:hover { color:#dc2626; }
.cart-summary-card { background:#fff; border-radius:14px; padding:1.5rem; box-shadow:0 2px 12px rgba(0,0,0,.06); position:sticky; top:5rem; }
.cart-summary-title { font-size:1rem; font-weight:700; color:#0f172a; margin-bottom:1.1rem; }
.cart-summary-row { display:flex; justify-content:space-between; font-size:.85rem; color:#374151; padding:.4rem 0; }
.cart-summary-total { display:flex; justify-content:space-between; font-size:1rem; font-weight:800; color:#0f172a; padding:.75rem 0 1rem; border-top:1.5px solid #f1f5f9; margin-top:.5rem; }
.cart-checkout-btn { display:block; background:var(--blue); color:#fff; text-align:center; padding:.85rem; border-radius:10px; font-weight:700; text-decoration:none; font-size:.92rem; transition:background .2s; }
.cart-checkout-btn:hover { background:#1a50e0; }
.cart-continue-link { display:block; text-align:center; color:#64748b; font-size:.78rem; margin-top:.85rem; text-decoration:none; }
.cart-empty { text-align:center; padding:4rem 2rem; color:#94a3b8; }
.cart-empty a { color:var(--blue); font-weight:600; text-decoration:none; }

/* â”€â”€ CHECKOUT PAGE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.checkout-layout { display:grid; grid-template-columns:1fr 320px; gap:2rem; align-items:start; }
.payment-methods { display:flex; flex-direction:column; gap:.55rem; margin-top:.4rem; }
.payment-method-opt { display:flex; align-items:center; gap:.58rem; padding:.62rem .72rem; border:1px solid #dbe6f4; border-radius:12px; cursor:pointer; transition:border-color .18s, box-shadow .18s, transform .18s, background .18s; background:#fff; }
.payment-method-opt:hover { border-color:#bfd3f8; transform:translateY(-1px); box-shadow:0 8px 18px rgba(15,23,42,.05); }
.payment-method-opt input[type=radio] { appearance:none; -webkit-appearance:none; margin:0; width:16px; height:16px; flex-shrink:0; border:1.7px solid #94a3b8; border-radius:999px; background:#fff; position:relative; box-shadow:none; }
.payment-method-opt input[type=radio]::after { content:""; position:absolute; inset:3px; border-radius:999px; background:transparent; transition:background .16s ease; }
.payment-method-opt input[type=radio]:checked { border-color:var(--blue); }
.payment-method-opt input[type=radio]:checked::after { background:var(--blue); }
.payment-method-label { display:flex; flex-direction:column; gap:.08rem; min-width:0; flex:1; }
.payment-method-label strong { font-size:.76rem; color:#0f172a; line-height:1.18; text-transform:uppercase; letter-spacing:.02em; }
.payment-method-label span { font-size:.68rem; color:#64748b; line-height:1.28; }
.payment-method-label small { font-size:.69rem; color:#153a97; line-height:1.28; font-weight:700; }
.checkout-wrap { max-width:1040px; margin:5rem auto 3rem; padding:0 1rem; }
.checkout-hero { display:flex; justify-content:space-between; gap:.85rem; align-items:flex-end; margin-bottom:.7rem; }
.checkout-title { margin-bottom:0; }
.checkout-intro { max-width:680px; margin:.12rem 0 0; font-size:.82rem; line-height:1.48; color:#64748b; }
.checkout-backlink, .checkout-continue-link { color:#64748b; font-size:.78rem; text-decoration:none; }
.checkout-backlink:hover, .checkout-continue-link:hover { color:var(--blue); }
.checkout-main-stack { display:flex; flex-direction:column; gap:.8rem; }
.checkout-form-card { background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%); border:1px solid #e6edf8; border-radius:16px; box-shadow:0 8px 22px rgba(15,23,42,.05); padding:.88rem; }
.checkout-section-title { font-size:.88rem; font-weight:800; color:#0f172a; margin-bottom:.64rem; }
.checkout-fields { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.68rem; }
.checkout-field.full { grid-column:1 / -1; }
.checkout-field label { display:block; margin-bottom:.24rem; font-size:.64rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#94a3b8; }
.checkout-field input, .checkout-select { width:100%; min-height:42px; border:1px solid #dbe6f4; border-radius:12px; padding:.68rem .8rem; font-size:.8rem; color:#0f172a; background:#fff; }
.checkout-field input:focus, .checkout-select:focus { outline:none; border-color:#60a5fa; box-shadow:0 0 0 4px rgba(96,165,250,.14); }
.checkout-summary-card { border-radius:16px; padding:.92rem; }
.checkout-summary-list { display:flex; flex-direction:column; gap:.6rem; margin-bottom:.75rem; }
.checkout-summary-row { align-items:flex-start; gap:.85rem; }
.checkout-summary-title { min-width:0; flex:1; white-space:normal; overflow-wrap:anywhere; line-height:1.45; }
.checkout-submit-btn { width:100%; border:none; border-radius:12px; min-height:42px; background:var(--blue); color:#fff; font-size:.82rem; font-weight:800; cursor:pointer; transition:background .2s ease, transform .2s ease; }
.checkout-submit-btn:hover { background:#1a50e0; transform:translateY(-1px); }
.checkout-submit-btn.is-disabled { background:#cbd5e1; cursor:not-allowed; transform:none; }
.checkout-alert { border-radius:14px; padding:1rem 1.1rem; margin-bottom:1rem; font-size:.86rem; line-height:1.55; }
.checkout-alert-error { background:#fef2f2; border:1.5px solid #fca5a5; color:#b91c1c; }
.checkout-empty-state { padding:.95rem 1rem; border-radius:14px; border:1.5px dashed #cbd5e1; background:#f8fafc; color:#64748b; font-size:.84rem; line-height:1.6; }
.checkout-auth-note { margin-bottom:.8rem; max-width:760px; padding:.8rem .92rem; font-size:.82rem; line-height:1.5; }
.checkout-delivery-options { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.48rem; }
.checkout-delivery-options .payment-method-opt { min-height:74px; align-items:flex-start; }
.checkout-delivery-options .payment-method-label strong { font-size:.74rem; }
.checkout-payment-options .payment-method-opt { min-height:54px; }
/* â”€â”€ FLIGHT SEARCH â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.flight-results-grid { display:flex; flex-direction:column; gap:1rem; max-width:800px; margin:0 auto; }
.flight-card { background:#fff; border-radius:14px; padding:1.25rem 1.5rem; box-shadow:0 2px 12px rgba(0,0,0,.06); display:flex; align-items:center; gap:1.5rem; transition:box-shadow .2s; }
.flight-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.1); }
.flight-card-route { flex:1; }
.flight-card-cities { font-size:1.05rem; font-weight:800; color:#0f172a; }
.flight-card-airline { font-size:.75rem; color:#94a3b8; margin-top:.15rem; }
.flight-card-times { font-size:.82rem; color:#374151; margin-top:.4rem; }
.flight-card-duration { font-size:.75rem; color:#64748b; }
.flight-card-price { text-align:right; }
.flight-card-amount { font-size:1.3rem; font-weight:800; color:#0f172a; }
.flight-card-currency { font-size:.72rem; color:#94a3b8; }
.flight-card-stops { font-size:.72rem; color:#64748b; margin-top:.2rem; }
.flight-search-form { background:#fff; border-radius:16px; padding:1.5rem; box-shadow:0 4px 20px rgba(0,0,0,.08); display:flex; gap:1rem; flex-wrap:wrap; align-items:flex-end; margin-bottom:2rem; }
.flight-field { flex:1; min-width:160px; }
.flight-field label { display:block; font-size:.75rem; font-weight:600; color:#64748b; margin-bottom:.35rem; }
.flight-field input { width:100%; padding:.65rem .85rem; border:1.5px solid #e2e8f0; border-radius:9px; font-size:.85rem; outline:none; box-sizing:border-box; transition:border-color .2s; }
.flight-field input:focus { border-color:var(--blue); }

.trip-toggle {
  padding: .8rem 1.15rem;
  border-radius: 999px;
  border: 1.5px solid var(--grey-200);
  background: var(--white);
  color: var(--grey-600);
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
}
.trip-toggle:hover {
  border-color: var(--blue);
  color: var(--navy);
}
.trip-toggle.active {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
  box-shadow: 0 8px 20px rgba(11,31,75,.16);
}

@media (max-width:768px) {
  .cart-layout, .checkout-layout { grid-template-columns:1fr; gap:1rem; }
  .cart-summary-card { position:static; }
  .checkout-wrap { margin:4.18rem auto 1.1rem; padding:0 .66rem; max-width:420px; }
  .checkout-hero { align-items:flex-start; flex-direction:column; gap:.16rem; margin-bottom:.28rem; }
  .checkout-title { font-size:.98rem; }
  .checkout-intro { font-size:.66rem; line-height:1.34; margin-top:0; }
  .checkout-backlink { font-size:.6rem; }
  .checkout-main-stack { gap:.62rem; }
  .checkout-form-card, .checkout-summary-card { padding:.66rem; border-radius:12px; }
  .checkout-section-title { font-size:.8rem; margin-bottom:.52rem; }
  .checkout-fields { grid-template-columns:1fr; gap:.48rem; }
  .checkout-field label { font-size:.58rem; margin-bottom:.14rem; }
  .checkout-field input, .checkout-select { min-height:36px; padding:.56rem .64rem; font-size:.68rem; border-radius:10px; }
  .payment-methods { gap:.36rem; }
  .payment-method-opt { gap:.44rem; padding:.48rem .54rem; border-radius:10px; }
  .payment-method-opt input[type=radio] { width:14px; height:14px; }
  .payment-method-opt input[type=radio]::after { inset:2.5px; }
  .payment-method-label strong { font-size:.68rem; }
  .payment-method-label span, .payment-method-label small, .checkout-continue-link { font-size:.58rem; }
  .checkout-submit-btn { min-height:36px; font-size:.72rem; border-radius:10px; }
  .checkout-delivery-options { grid-template-columns:1fr; gap:.42rem; }
  .checkout-delivery-options .payment-method-opt,
  .checkout-payment-options .payment-method-opt { min-height:unset; }
  .checkout-auth-note { padding:.56rem .62rem; font-size:.64rem; line-height:1.3; margin-bottom:.54rem; }
  .cart-wrap { margin:4.5rem auto 2.4rem; padding:0 .78rem; max-width:420px; }
  .cart-title { font-size:1.22rem; margin-bottom:.85rem; }
  .cart-item { display:grid; grid-template-columns:60px minmax(0,1fr); gap:.62rem; padding:.72rem .74rem; align-items:start; border-radius:12px; }
  .cart-item-img { width:60px; height:52px; border-radius:7px; }
  .cart-item-info { min-width:0; }
  .cart-item-name { font-size:.72rem; line-height:1.26; white-space:normal; overflow:visible; text-overflow:clip; }
  .cart-item-meta { font-size:.62rem; line-height:1.3; }
  .cart-item-price { grid-column:2; font-size:.78rem; }
  .cart-item > form:first-of-type { grid-column:2; justify-self:start; }
  .cart-qty-ctrl { gap:.3rem; }
  .cart-qty-ctrl button { width:24px; height:24px; font-size:.82rem; }
  .cart-qty-ctrl span { min-width:16px; font-size:.74rem; }
  .cart-item > form:last-of-type { position:absolute; top:.58rem; right:.58rem; }
  .cart-item { position:relative; }
  .cart-remove { margin-left:0; font-size:.68rem; }
  .cart-summary-card { padding:.88rem; border-radius:12px; max-width:100%; }
  .cart-summary-title { font-size:.86rem; margin-bottom:.78rem; }
  .cart-summary-row { font-size:.7rem; }
  .cart-summary-total { font-size:.84rem; padding:.58rem 0 .8rem; }
  .cart-checkout-btn { padding:.58rem .64rem; font-size:.72rem; border-radius:8px; width:100%; }
  .cart-continue-link { font-size:.66rem; margin-top:.62rem; }
  .product-grid { grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); }
  .flight-card { flex-direction:column; align-items:flex-start; }
  .flight-card-price { text-align:left; }
}

@media (max-width:420px) {
  .cart-wrap, .checkout-wrap { padding:0 .62rem; max-width:352px; }
  .cart-title { font-size:.96rem; }
  .checkout-hero { gap:.14rem; }
  .checkout-intro { font-size:.6rem; }
  .checkout-form-card, .checkout-summary-card { padding:.6rem; border-radius:10px; }
  .checkout-field label { font-size:.54rem; }
  .checkout-field input, .checkout-select { min-height:34px; padding:.52rem .58rem; font-size:.64rem; }
  .payment-method-opt { padding:.44rem .5rem; gap:.36rem; }
  .payment-method-opt input[type=radio] { width:13px; height:13px; }
  .payment-method-opt input[type=radio]::after { inset:2px; }
  .payment-method-label strong { font-size:.64rem; }
  .payment-method-label span, .payment-method-label small, .checkout-backlink, .checkout-continue-link { font-size:.56rem; }
  .checkout-submit-btn { min-height:34px; font-size:.66rem; }
  .cart-item { grid-template-columns:54px minmax(0,1fr); gap:.56rem; padding:.66rem .66rem .72rem; border-radius:11px; }
  .cart-item-img { width:54px; height:48px; border-radius:6px; }
  .cart-item-name { font-size:.66rem; }
  .cart-item-meta { font-size:.58rem; }
  .cart-item-price { font-size:.72rem; }
  .cart-summary-card { padding:.8rem; border-radius:11px; }
  .cart-checkout-btn { font-size:.66rem; padding:.54rem .58rem; border-radius:7px; }
  .cart-continue-link { font-size:.62rem; }
}









/* â”€â”€ PORTAL / AUTH SHELL â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.portal-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  min-height: 100vh;
}
.portal-sidebar {
  background: linear-gradient(180deg, #0f172a 0%, #16253f 100%);
  color: #e5eefc;
  padding: 1.5rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  border-right: 1px solid rgba(148, 163, 184, .12);
}
.portal-sidebar .portal-brand {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: #fff;
  text-decoration: none;
  font-family: var(--ff-display);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.portal-sidebar .portal-brand span {
  font-size: .7rem;
  color: #93c5fd;
}
.portal-account-card {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .95rem 1rem;
  border-radius: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(148, 163, 184, .14);
}
.portal-account-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  color: #fff;
  font-size: .82rem;
  font-weight: 800;
}
.portal-account-name {
  color: #fff;
  font-size: .92rem;
  font-weight: 700;
}
.portal-account-role {
  color: #9fb5d1;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.portal-nav-section {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.portal-nav-label {
  color: #7f93b0;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 0 .35rem;
}
.portal-nav-link {
  display: block;
  padding: .8rem .95rem;
  border-radius: 12px;
  color: #d8e4f5;
  text-decoration: none;
  font-size: .82rem;
  font-weight: 600;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.portal-nav-link:hover,
.portal-nav-link.active {
  background: rgba(255,255,255,.08);
  color: #fff;
  transform: translateX(2px);
}
.portal-main {
  min-width: 0;
  background: #f5f8fc;
  padding: 1.4rem;
}
.portal-topbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.2rem;
}
.portal-topbar h1 {
  margin: 0;
  font-size: 1.8rem;
  color: #0f172a;
}
.portal-topbar p {
  margin: .35rem 0 0;
  color: #64748b;
  max-width: 760px;
}
.portal-top-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}
.portal-hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, .95fr);
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 1.35rem 1.4rem;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, .16), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #eef5ff 100%);
  border: 1px solid rgba(191, 219, 254, .9);
  box-shadow: 0 18px 40px rgba(15, 23, 42, .08);
}
.portal-hero-panel-compact {
  margin-bottom: 1.1rem;
}
.portal-kicker {
  color: #5b79b4;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: .55rem;
}
.portal-hero-panel h2 {
  margin: 0;
  color: #0f172a;
  font-size: clamp(1.3rem, 2vw, 1.9rem);
  line-height: 1.12;
}
.portal-hero-panel p {
  margin: .8rem 0 0;
  color: #5b6b82;
  line-height: 1.7;
  font-size: .94rem;
  max-width: 760px;
}
.portal-hero-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .85rem;
  align-content: start;
}
.portal-quick-card {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  min-height: 120px;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid rgba(191, 219, 254, .95);
  background: rgba(255,255,255,.86);
  color: #0f172a;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.portal-quick-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(15, 23, 42, .1);
  border-color: rgba(96, 165, 250, .95);
}
.portal-quick-card strong {
  font-size: .95rem;
  line-height: 1.25;
}
.portal-quick-card span:last-child {
  color: #64748b;
  font-size: .82rem;
  line-height: 1.45;
}
.portal-quick-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: linear-gradient(135deg, #dbeafe 0%, #eff6ff 100%);
  color: #1d4ed8;
  font-size: 1.05rem;
  font-weight: 800;
}
.portal-quick-card-button {
  width: 100%;
  appearance: none;
  text-align: left;
  cursor: pointer;
  font: inherit;
}
.portal-grid {
  display: grid;
  gap: 1rem;
}
.portal-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1rem;
}
.portal-main .metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 1rem;
  margin-bottom: 0;
}
.portal-main .metric-card {
  min-width: 0;
  border-radius: 18px;
  padding: 1.15rem 1.2rem;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .06);
}
.portal-main .metric-label {
  font-size: .72rem;
  letter-spacing: .08em;
}
.portal-main .metric-value {
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.1;
}
.portal-main .metric-trend {
  margin-top: .45rem;
}
.portal-main .table-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100%;
  border-radius: 18px;
  box-shadow: 0 12px 32px rgba(15, 23, 42, .06);
}
.portal-main .table-card-head {
  gap: .85rem;
  flex-wrap: wrap;
}
.portal-main .table-card-head h3 {
  margin: 0;
}
.portal-main .data-table {
  width: 100%;
  table-layout: fixed;
}
.portal-main .data-table th,
.portal-main .data-table td {
  vertical-align: middle;
}
.portal-main .data-table td strong,
.portal-main .portal-list-item strong {
  color: #0f172a;
}
.portal-list-item > div {
  min-width: 0;
}
.portal-list {
  display: flex;
  flex-direction: column;
}
.portal-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .95rem 0;
  border-bottom: 1px solid var(--grey-100);
}
.portal-list-item .badge {
  flex-shrink: 0;
}
.portal-list-item:last-child {
  border-bottom: 0;
}
.portal-muted,
.portal-empty {
  color: #64748b;
  font-size: .85rem;
}
.portal-main .section-link {
  flex-shrink: 0;
}
.portal-pane {
  border: 1px solid rgba(191, 219, 254, .85);
  border-radius: 18px;
  background: linear-gradient(180deg, #f9fbff 0%, #f2f7ff 100%);
  padding: 1rem 1.05rem;
}
.portal-pane-soft {
  background: #f8fbff;
}
.portal-pane-stat {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .55rem;
}
.portal-pane-stat span {
  color: #5b79b4;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.portal-pane-stat strong {
  color: #0f172a;
  font-size: .98rem;
}
.portal-pane-copy {
  margin: 0;
  color: #64748b;
  font-size: .82rem;
  line-height: 1.65;
}
.portal-field label {
  display: block;
  margin-bottom: .45rem;
  color: #475569;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.portal-field input[type="file"] {
  width: 100%;
  padding: .8rem .95rem;
  border-radius: 14px;
  border: 1.5px dashed #bfd6f6;
  background: #f8fbff;
  color: #334155;
}
.portal-alert {
  margin-bottom: 1rem;
  padding: .95rem 1.05rem;
  border-radius: 16px;
  border: 1px solid transparent;
  font-size: .82rem;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .05);
}
.portal-alert-ok {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #166534;
}
.portal-alert-err {
  background: #fef2f2;
  border-color: #fecaca;
  color: #b91c1c;
}
.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: start center;
  padding: 4.2rem .9rem 1.2rem;
}
.auth-shell .auth-card {
  width: min(100%, 408px);
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(216, 226, 239, .95);
  border-radius: 20px;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .08);
  padding: 1rem .96rem .96rem;
}
.auth-shell .auth-card > .portal-brand {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  text-decoration: none;
  color: #0f172a;
  font-family: var(--ff-display);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: .54rem;
}
.auth-shell .auth-card > .portal-brand span {
  color: var(--blue);
  font-size: .56rem;
}
.auth-shell .auth-card h1 {
  margin: 0;
  font-size: .92rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.1;
  margin-bottom: 1rem;
}
.auth-shell .auth-card > p {
  margin: .2rem 0 .72rem;
  color: #64748b;
  line-height: 1.28;
  font-size: .72rem;
}
.auth-alert {
  margin-bottom: 1rem;
  padding: .9rem 1rem;
  border-radius: 14px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #b91c1c;
  font-size: .88rem;
}
.auth-alert-success {
  background: #ecfdf3;
  border-color: #bbf7d0;
  color: #166534;
}
.auth-form {
  display: grid;
  gap: .62rem;
}
.auth-label {
  color: #475569;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.auth-input {
  width: 100%;
  min-height: 44px;
  padding: .66rem .8rem;
  border-radius: 11px;
  border: 1.5px solid #d6e0ec;
  background: #fff;
  color: #0f172a;
  font-size: .86rem;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.auth-input:focus {
  border-color: #60a5fa;
  box-shadow: 0 0 0 4px rgba(96, 165, 250, .15);
}
.auth-submit {
  width: 100%;
  min-height: 42px;
  margin-top: .12rem;
  font-size: .8rem;
}
.auth-links,
.auth-switch-row {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: .78rem;
}
.auth-links a,
.auth-switch-row a {
  color: #1d4ed8;
  text-decoration: none;
  font-size: .76rem;
  font-weight: 600;
}
.auth-switch-row a.active {
  color: #0f172a;
}
.auth-choice-stack{display:grid;gap:.58rem;margin-top:.58rem;}
.auth-choice-primary{display:flex;align-items:center;justify-content:center;min-height:46px;border-radius:10px;background:var(--navy);color:#fff;text-decoration:none;font-size:.8rem;font-weight:800;box-shadow:0 10px 18px rgba(11,31,75,.18);}
.auth-choice-foot{margin-top:.66rem;text-align:center;font-size:.74rem;color:#334155;line-height:1.3;}
.auth-choice-foot a{color:var(--navy-mid);text-decoration:none;font-weight:800;}
.auth-form-note{font-size:.68rem;color:#7c8ba1;line-height:1.36;margin-top:-.04rem;}
.auth-check{display:flex;align-items:flex-start;gap:.46rem;margin-top:.1rem;font-size:.72rem;color:#334155;}
.auth-check input{margin-top:.2rem;width:16px;height:16px;accent-color:#16a34a;}
.auth-check a{color:#16a34a;text-decoration:none;font-weight:700;}
.auth-split-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;}
@media (max-width: 980px) {
  .portal-shell {
    grid-template-columns: 1fr;
  }
  .portal-sidebar {
    border-right: 0;
    border-bottom: 1px solid rgba(148, 163, 184, .12);
  }
  .portal-grid-2 {
    grid-template-columns: 1fr;
  }
  .portal-hero-panel {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px) {
  .portal-main {
    padding: 1rem;
  }
  .portal-topbar {
    flex-direction: column;
  }
  .portal-main .metric-card {
    padding: 1rem;
  }
  .portal-main .table-card-head {
    padding: .95rem 1rem;
  }
  .portal-main .data-table th,
  .portal-main .data-table td {
    padding-left: .9rem;
    padding-right: .9rem;
    font-size: .78rem;
  }
  .portal-list-item {
    align-items: flex-start;
  }
  .portal-hero-panel {
    padding: 1rem;
    border-radius: 18px;
  }
  .portal-hero-actions {
    grid-template-columns: 1fr;
  }
  .portal-quick-card {
    min-height: 0;
  }
  .auth-shell {
    padding: 3.9rem .8rem 1rem;
  }
  .auth-shell .auth-card {
    width:min(100%,320px);
    padding: .92rem .88rem .88rem;
    border-radius: 16px;
    box-shadow: 0 16px 34px rgba(15, 23, 42, .08);
  }
  .auth-shell .auth-card > .portal-brand{font-size:.76rem;margin-bottom:.46rem;gap:.28rem;}
  .auth-shell .auth-card > .portal-brand span{font-size:.52rem;}
  .auth-shell .auth-card h1{font-size:.9rem;line-height:1.12;margin-bottom:.8rem;}
  .auth-shell .auth-card > p{font-size:.66rem;margin:.18rem 0 .54rem;line-height:1.3;}
  .auth-form{gap:.46rem;}
  .auth-label{font-size:.5rem;letter-spacing:.1em;}
  .auth-input{min-height:38px;padding:.56rem .68rem;font-size:.8rem;border-radius:9px;}
  .auth-submit{min-height:40px;font-size:.74rem;margin-top:.08rem;}
  .auth-links,
  .auth-switch-row{gap:.42rem;margin-top:.58rem;}
  .auth-links a,.auth-switch-row a{font-size:.7rem;}
  .auth-choice-stack{gap:.5rem;margin-top:.5rem;}
  .auth-choice-primary{min-height:44px;font-size:.76rem;border-radius:8px;}
  .auth-choice-foot{margin-top:.5rem;font-size:.68rem;line-height:1.24;}
  .auth-form-note{font-size:.62rem;line-height:1.24;}
  .auth-check{font-size:.66rem;gap:.36rem;margin-top:.08rem;}
  .auth-check input{width:14px;height:14px;}
  .auth-split-grid{grid-template-columns:1fr;gap:.46rem;}
}



@media (max-width:900px){.nav-cart-btn-mobile{display:flex;}}




