/* ===========================================================================
   Blue Star Shipping Group — design system
   =========================================================================== */
:root{
  --navy:#0a2a66;        /* deep brand blue */
  --navy-2:#0d3a8a;
  --blue:#1657c4;        /* primary blue */
  --blue-bright:#2f7be0;
  --red:#e11b22;         /* brand red */
  --red-dark:#c2151b;
  --ink:#16202e;         /* near-black text */
  --body:#475569;        /* body text */
  --muted:#8a96a8;
  --line:#e6eaf1;
  --bg:#ffffff;
  --bg-soft:#f4f7fc;
  --bg-soft-2:#eef3fb;
  --gold:#f4b740;
  --radius:14px;
  --radius-lg:20px;
  --shadow-sm:0 2px 10px rgba(16,40,80,.06);
  --shadow:0 14px 40px rgba(16,40,80,.10);
  --shadow-lg:0 30px 70px rgba(16,40,80,.16);
  --maxw:1200px;
  --head:'Poppins',system-ui,sans-serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--body);background:var(--bg);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--head);color:var(--ink);line-height:1.18;margin:0 0 .5em;font-weight:700}
p{margin:0 0 1rem}
a{color:var(--blue);text-decoration:none;transition:color .2s}
a:hover{color:var(--navy)}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
section{position:relative}

/* ---- buttons ------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--head);font-weight:600;font-size:.95rem;padding:13px 26px;border-radius:9px;border:2px solid transparent;cursor:pointer;transition:.22s ease;white-space:nowrap;letter-spacing:.2px}
.btn .btn-ic{width:18px;height:18px}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 20px rgba(225,27,34,.28)}
.btn-red:hover{background:var(--red-dark);color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(225,27,34,.36)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 8px 20px rgba(22,87,196,.28)}
.btn-blue:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:#eef3fb;color:var(--navy);transform:translateY(-2px)}
.btn-outline{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-outline-white{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.btn-outline-white:hover{background:#fff;color:var(--navy)}
.btn-lg{padding:16px 32px;font-size:1.02rem}
.btn-block{width:100%;justify-content:center}

/* ---- header -------------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .25s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(16,40,80,.09)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px}
.brand-logo{height:50px;width:auto}
.main-nav>ul{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.main-nav a{color:var(--ink);font-family:var(--head);font-weight:500;font-size:.95rem;padding:10px 14px;border-radius:8px;display:inline-flex;align-items:center;gap:6px;position:relative}
.main-nav a:hover,.main-nav a.active{color:var(--blue)}
.main-nav a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:2px;height:2px;background:var(--red);border-radius:2px}
.caret{display:inline-flex;width:15px;transition:transform .2s}
.caret svg{width:15px;height:15px;stroke-width:2.4}
.has-dropdown{position:relative}
.has-dropdown:hover .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:248px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);list-style:none;margin:0;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{padding:11px 12px;border-radius:9px;color:var(--body);font-weight:500}
.dropdown a:hover{background:var(--bg-soft);color:var(--blue)}
.dd-ic{width:18px;height:18px;color:var(--blue);flex:0 0 auto}
.header-actions{display:flex;align-items:center;gap:14px}
.nav-toggle,.nav-close{display:none;background:none;border:0;cursor:pointer;color:var(--navy)}
.nav-toggle svg,.nav-close svg{width:28px;height:28px}
.nav-cta-mobile{display:none}
.nav-overlay{display:none}

/* ---- generic section heading -------------------------------------------- */
.section{padding:92px 0}
.section-soft{background:var(--bg-soft)}
.eyebrow{font-family:var(--head);font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:.82rem;color:var(--red);margin:0 0 8px}
.section-head{text-align:center;max-width:720px;margin:0 auto 54px}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem);color:var(--navy)}
.section-head h2 .u,.heading-underline{position:relative}
.head-rule{width:64px;height:4px;background:var(--red);border-radius:3px;margin:16px auto 0}
.head-rule.left{margin-left:0}
.lead{font-size:1.06rem;color:var(--body)}

/* ---- hero ---------------------------------------------------------------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:#06203f}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center right;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(5,20,45,.93) 0%,rgba(6,26,60,.78) 38%,rgba(6,26,60,.25) 68%,rgba(6,26,60,.05) 100%)}
.hero .container{position:relative;z-index:2}
.hero-inner{max-width:640px;padding:60px 0}
.hero .eyebrow{color:#7fb4ff}
.hero h1{color:#fff;font-size:clamp(2.3rem,5.4vw,3.85rem);font-weight:800;line-height:1.08;letter-spacing:-.5px;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero h1 .red{color:#ff5a5f;display:block}
.hero p.hero-sub{font-size:1.18rem;color:#dce7f7;max-width:540px;margin:18px 0 30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-trust{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero-trust div{display:flex;align-items:center;gap:9px;font-size:.92rem;color:#cfe0f7}
.hero-trust svg{width:20px;height:20px;color:#5ee08a}
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;z-index:3;line-height:0}
.hero-wave svg{width:100%;height:auto;display:block}

/* ---- services cards ------------------------------------------------------ */
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:22px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 22px;text-align:center;transition:.25s;position:relative;overflow:hidden}
.svc-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--red));transform:scaleX(0);transition:transform .3s;transform-origin:left}
.svc-card:hover{box-shadow:var(--shadow);transform:translateY(-6px);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-ic-wrap{width:74px;height:74px;margin:0 auto 18px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(150deg,#eaf1fd,#dbe8fb);color:var(--blue);transition:.25s}
.svc-card:hover .svc-ic-wrap{background:linear-gradient(150deg,var(--blue),var(--navy));color:#fff}
.svc-ic-wrap svg{width:36px;height:36px}
.svc-card h3{font-size:1.12rem;color:var(--navy);margin-bottom:10px}
.svc-card p{font-size:.92rem;margin-bottom:16px;color:var(--body)}
.svc-more{font-family:var(--head);font-weight:600;font-size:.9rem;color:var(--blue);display:inline-flex;align-items:center;gap:7px}
.svc-more svg{width:16px;height:16px;transition:transform .2s}
.svc-card:hover .svc-more svg{transform:translateX(4px)}

/* ---- why choose us ------------------------------------------------------- */
.why{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:center}
.why-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);min-height:420px}
.why-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.why h2{font-size:clamp(1.7rem,3.3vw,2.4rem);color:var(--navy)}
.why-list{list-style:none;margin:22px 0 28px;padding:0;display:grid;gap:14px}
.why-list li{display:flex;align-items:flex-start;gap:12px;font-weight:500;color:var(--ink)}
.why-list .tick{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;margin-top:1px}
.why-list .tick svg{width:15px;height:15px;stroke-width:3}

/* ---- stats band ---------------------------------------------------------- */
.stats-band{background:linear-gradient(120deg,var(--navy),var(--navy-2));border-radius:var(--radius-lg);padding:40px 30px;box-shadow:var(--shadow);margin-top:64px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat{color:#fff;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-10px;top:10%;height:80%;width:1px;background:rgba(255,255,255,.16)}
.stat svg{width:34px;height:34px;color:#7fb4ff;margin-bottom:4px}
.stat .num{font-family:var(--head);font-weight:800;font-size:2.1rem;line-height:1}
.stat .lbl{font-size:.86rem;color:#bcd2f2}

/* ---- testimonials -------------------------------------------------------- */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tst-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.tst-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.tst-quote-ic{width:38px;height:38px;color:var(--blue);opacity:.9}
.stars{display:flex;gap:3px;color:var(--gold)}
.stars svg{width:17px;height:17px;fill:var(--gold);stroke:var(--gold)}
.tst-card p{color:var(--body);font-size:.96rem;flex:1}
.tst-author{display:flex;align-items:center;gap:13px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.tst-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(150deg,var(--blue),var(--navy));color:#fff;display:grid;place-items:center;font-family:var(--head);font-weight:700;font-size:1.05rem;flex:0 0 auto}
.tst-author .nm{font-family:var(--head);font-weight:600;color:var(--navy);font-size:.98rem;line-height:1.2}
.tst-author .ti{font-size:.84rem;color:var(--muted)}

/* ---- CTA band ------------------------------------------------------------ */
.cta-band{background:linear-gradient(120deg,var(--blue),var(--navy));color:#fff;padding:54px 0}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.cta-band h2{color:#fff;font-size:1.9rem;margin-bottom:6px}
.cta-band p{color:#cfe0f7;margin:0}
.cta-band-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ---- footer -------------------------------------------------------------- */
.site-footer{background:#071f4a;color:#aebfdb;font-size:.94rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:40px;padding:64px 24px 44px}
.footer-logo-badge{display:inline-flex;background:#fff;padding:12px 16px;border-radius:12px;margin-bottom:18px}
.footer-logo-badge img{height:46px}
.footer-brand p{color:#9fb2d4;max-width:320px}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#cdddf6}
.socials a svg{width:18px;height:18px}
.socials a:hover{background:var(--red);color:#fff}
.footer-col h3{color:#fff;font-size:1.04rem;margin-bottom:18px}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.footer-col a{color:#aebfdb}
.footer-col a:hover{color:#fff;padding-left:3px}
.footer-contact ul{gap:15px}
.footer-contact li{display:flex;gap:11px;align-items:flex-start}
.footer-contact svg{width:19px;height:19px;color:var(--blue-bright);flex:0 0 auto;margin-top:2px}
.footer-contact a{color:#aebfdb}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;flex-wrap:wrap;gap:10px;font-size:.88rem;color:#8aa0c6}
.footer-bottom-inner p{margin:0}
.footer-legal a{color:#aebfdb}
.footer-legal a:hover{color:#fff}

/* ---- page hero (inner pages) -------------------------------------------- */
.page-hero{position:relative;color:#fff;padding:84px 0 76px;background:var(--navy);overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(7,25,60,.92),rgba(7,25,60,.72));z-index:1}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(2rem,4.5vw,3rem);font-weight:800}
.page-hero p{color:#cfe0f7;max-width:640px;font-size:1.08rem;margin:6px 0 0}
.crumbs{display:flex;gap:8px;align-items:center;font-size:.9rem;color:#9fc0ef;margin-bottom:14px}
.crumbs a{color:#cfe0f7}.crumbs a:hover{color:#fff}
.crumbs span{opacity:.6}

/* ---- about --------------------------------------------------------------- */
.about-split{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:center}
.about-media{position:relative}
.about-media .img-main{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.about-media .img-badge{position:absolute;right:-18px;bottom:-22px;background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;border-radius:16px;padding:20px 24px;box-shadow:var(--shadow);text-align:center}
.about-media .img-badge .big{font-family:var(--head);font-weight:800;font-size:2rem;line-height:1}
.about-media .img-badge .sm{font-size:.82rem;opacity:.92}
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.mvv-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px 26px;box-shadow:var(--shadow-sm)}
.mvv-card .ic{width:60px;height:60px;border-radius:14px;background:linear-gradient(150deg,var(--blue),var(--navy));color:#fff;display:grid;place-items:center;margin-bottom:16px}
.mvv-card .ic svg{width:30px;height:30px}
.mvv-card h3{color:var(--navy);font-size:1.2rem}

/* ---- team ---------------------------------------------------------------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.team-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s}
.team-card:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.team-photo{aspect-ratio:1/1;overflow:hidden;background:var(--bg-soft)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:.4s}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-body{padding:22px 24px}
.team-body .nm{font-family:var(--head);font-weight:700;color:var(--navy);font-size:1.18rem;margin-bottom:2px}
.team-body .ro{color:var(--red);font-weight:600;font-size:.9rem;margin-bottom:10px}
.team-body p{font-size:.92rem;color:var(--body);margin:0}

/* ---- services detailed --------------------------------------------------- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:14px 0}
.svc-row.rev .svc-row-media{order:2}
.svc-row-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);position:relative;min-height:360px}
.svc-row-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.svc-row-badge{position:absolute;left:20px;top:20px;background:rgba(255,255,255,.95);color:var(--navy);width:58px;height:58px;border-radius:14px;display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.svc-row-badge svg{width:30px;height:30px;color:var(--blue)}
.svc-row h2{color:var(--navy);font-size:1.85rem}
.svc-feat{list-style:none;padding:0;margin:18px 0 24px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.svc-feat li{display:flex;gap:10px;align-items:flex-start;font-weight:500;color:var(--ink);font-size:.95rem}
.svc-feat .tick{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:#e8f0fe;color:var(--blue);display:grid;place-items:center}
.svc-feat .tick svg{width:13px;height:13px;stroke-width:3}

/* ---- tracking ------------------------------------------------------------ */
.track-hero{background:linear-gradient(115deg,var(--navy),#06203f);color:#fff;padding:70px 0 120px;position:relative;overflow:hidden}
.track-hero .container{position:relative;z-index:2}
.track-hero-bg{position:absolute;inset:0;opacity:.22;background-size:cover;background-position:center;z-index:0}
.track-box{max-width:760px;margin:0 auto;text-align:center}
.track-box h1{color:#fff;font-size:clamp(2rem,4vw,2.8rem)}
.track-box p{color:#cfe0f7;margin-bottom:26px}
.track-form{display:flex;gap:10px;background:#fff;padding:10px;border-radius:14px;box-shadow:var(--shadow-lg);max-width:620px;margin:0 auto}
.track-form .field{flex:1;display:flex;align-items:center;gap:10px;padding:0 8px 0 16px}
.track-form .field svg{width:22px;height:22px;color:var(--muted);flex:0 0 auto}
.track-form input{border:0;outline:0;font-size:1.05rem;width:100%;padding:14px 0;color:var(--ink);font-family:var(--sans)}
.track-form .btn{flex:0 0 auto}
.track-hint{margin-top:16px;font-size:.9rem;color:#bcd2f2}
.track-hint code{background:rgba(255,255,255,.14);padding:3px 9px;border-radius:6px;color:#fff;cursor:pointer;font-family:ui-monospace,monospace}
.track-results{margin-top:-80px;position:relative;z-index:5;padding-bottom:90px}
.track-panel{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line)}
/* branded waybill header with scannable barcode */
.track-docbar{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  padding:20px 28px;background:linear-gradient(115deg,var(--navy),#06203f);color:#fff}
.track-docbar-id{display:flex;flex-direction:column;gap:5px;min-width:0}
.track-docbar-label{font-family:var(--head);text-transform:uppercase;letter-spacing:2px;font-size:.72rem;font-weight:700;color:#7fb4ff}
.track-docbar-num{font-family:var(--head);font-weight:700;font-size:clamp(1.15rem,2.6vw,1.5rem);letter-spacing:.5px;color:#fff}
.track-barcode{background:#fff;border-radius:8px;padding:10px 14px 7px;display:flex;flex-direction:column;align-items:center;gap:5px;box-shadow:var(--shadow-sm)}
.track-barcode .bars{display:flex;align-items:stretch;height:46px}
.track-barcode .bars i{display:block;background:#10203a}
.track-barcode .bars i.sp{background:#fff}
.track-barcode-num{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:2px;font-size:.72rem;color:#10203a}
.track-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-bottom:1px solid var(--line)}
.track-summary .cell{background:#fff;padding:22px 24px;position:relative}
.track-summary .cell+.cell::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:1px;background:var(--line)}
.track-summary .cell .k{font-size:.74rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:600;margin-bottom:6px}
.track-summary .cell .v{font-family:var(--head);font-weight:700;color:var(--navy);font-size:1.05rem}
.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:30px;font-family:var(--head);font-weight:600;font-size:.86rem}
.status-pill .dot{width:9px;height:9px;border-radius:50%;background:currentColor;box-shadow:0 0 0 4px rgba(255,255,255,.0)}
.status-intransit{background:#e7f0ff;color:#1657c4}
.status-delivered{background:#e4f7ec;color:#108a45}
.status-pending{background:#fff3e0;color:#b9760a}
.status-outfordelivery{background:#eae7ff;color:#5b3cc4}
.status-exception{background:#fdeaea;color:#d12b2b}
.track-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:14px 24px;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.track-actions-note{font-size:.82rem;color:var(--muted);font-family:var(--head);font-weight:600;text-transform:uppercase;letter-spacing:1px}
.btn-bl{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;font-family:var(--head);font-weight:600;font-size:.88rem;padding:10px 18px;border-radius:9px;transition:background .15s,transform .15s}
.btn-bl:hover{background:var(--navy-2);color:#fff;transform:translateY(-1px)}
.btn-bl svg{width:16px;height:16px}
.track-main{display:grid;grid-template-columns:1.2fr 1fr;gap:0}
#trackMap{height:520px;width:100%;background:#e9eef6}
.track-progress-wrap{padding:30px 32px;max-height:520px;overflow-y:auto}
.track-progress-wrap h3{color:var(--navy);font-size:1.2rem;margin-bottom:6px}
.route-line{display:flex;align-items:center;gap:12px;margin:16px 0 26px;padding:16px;background:var(--bg-soft);border-radius:12px}
.route-line .ep{flex:1}
.route-line .ep .city{font-family:var(--head);font-weight:700;color:var(--navy)}
.route-line .ep .role{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.route-line .conn{flex:0 0 auto;color:var(--blue);display:flex;align-items:center}
.route-line .conn svg{width:34px;height:34px}
.timeline{list-style:none;margin:0;padding:0;position:relative}
.timeline li{position:relative;padding:0 0 26px 34px}
.timeline li::before{content:"";position:absolute;left:9px;top:22px;bottom:-4px;width:2px;background:var(--line)}
.timeline li:last-child::before{display:none}
.timeline .node{position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--line);z-index:1}
.timeline li.done .node{border-color:var(--blue);background:var(--blue)}
.timeline li.current .node{border-color:var(--red);background:#fff;box-shadow:0 0 0 5px rgba(225,27,34,.16);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(225,27,34,.28)}70%{box-shadow:0 0 0 9px rgba(225,27,34,0)}100%{box-shadow:0 0 0 0 rgba(225,27,34,0)}}
.timeline .tl-loc{font-family:var(--head);font-weight:600;color:var(--navy);font-size:1rem}
.timeline .tl-desc{font-size:.92rem;color:var(--body)}
.timeline .tl-time{font-size:.82rem;color:var(--muted);margin-top:2px}
.timeline li.current .tl-loc{color:var(--red)}
.track-details{padding:26px 32px 32px;border-top:1px solid var(--line)}
.track-details h3{color:var(--navy);font-size:1.2rem;margin:0 0 16px}
.td-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.td-grid .td{background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:13px 15px}
.td-grid .td .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:600;margin-bottom:4px}
.td-grid .td .v{font-family:var(--head);font-weight:600;color:var(--navy);font-size:.95rem;word-break:break-word}
.track-error{max-width:620px;margin:24px auto 0;background:#fdeaea;border:1px solid #f5c6c6;color:#b3261e;padding:16px 20px;border-radius:12px;text-align:center;font-weight:500}
.track-empty{text-align:center;padding:80px 24px;color:var(--muted)}
/* tracking landing / empty state */
.track-intro{padding:40px 34px 32px}
.track-intro-head{text-align:center;margin-bottom:28px}
.track-intro-head h2{color:var(--navy);font-size:clamp(1.4rem,2.6vw,1.85rem);margin:0 0 6px}
.track-intro-head p{color:var(--muted);margin:0;font-size:.96rem}
.track-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step}
.track-step{counter-increment:step;text-align:center;padding:28px 20px 24px;background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;position:relative}
.track-step::before{content:counter(step);position:absolute;top:12px;left:14px;width:22px;height:22px;border-radius:50%;background:#fff;border:1.5px solid var(--line);color:var(--muted);font-family:var(--head);font-weight:700;font-size:.72rem;display:grid;place-items:center}
.track-step .ts-ic{width:54px;height:54px;border-radius:14px;display:inline-grid;place-items:center;background:linear-gradient(150deg,var(--blue),var(--navy));color:#fff;margin-bottom:14px}
.track-step .ts-ic svg{width:26px;height:26px}
.track-step h3{color:var(--navy);font-size:1.08rem;margin:0 0 7px}
.track-step p{color:var(--body);font-size:.9rem;margin:0;line-height:1.55}
.track-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 30px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.track-trust span{display:inline-flex;align-items:center;gap:8px;font-family:var(--head);font-weight:600;font-size:.88rem;color:var(--navy)}
.track-trust svg{width:18px;height:18px;color:var(--blue)}
.track-help{text-align:center;margin:20px 0 0;font-size:.92rem;color:var(--muted)}
.track-help a{color:var(--blue);font-weight:600}

/* ---- forms --------------------------------------------------------------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:38px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg.full{grid-column:1/-1}
.fg label{font-family:var(--head);font-weight:600;font-size:.86rem;color:var(--navy)}
.fg label .req{color:var(--red)}
.fg input,.fg select,.fg textarea{font-family:var(--sans);font-size:.98rem;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;background:#fcfdff;color:var(--ink);transition:.18s;width:100%}
.fg textarea{min-height:130px;resize:vertical}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(22,87,196,.1);background:#fff}
.form-alert{padding:14px 18px;border-radius:10px;margin-bottom:20px;font-weight:500}
.form-alert.ok{background:#e4f7ec;color:#108a45;border:1px solid #b6e6c8}
.form-alert.err{background:#fdeaea;color:#c2151b;border:1px solid #f3c4c4}

/* ---- contact ------------------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:start}
.contact-cards{display:grid;gap:16px}
.contact-card{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.contact-card .ic{flex:0 0 auto;width:50px;height:50px;border-radius:12px;background:linear-gradient(150deg,#eaf1fd,#dbe8fb);color:var(--blue);display:grid;place-items:center}
.contact-card .ic svg{width:24px;height:24px}
.contact-card h4{margin:0 0 4px;color:var(--navy);font-size:1.05rem}
.contact-card p,.contact-card a{margin:0;color:var(--body);font-size:.95rem}
.contact-card a:hover{color:var(--blue)}
#contactMap{height:340px;border-radius:var(--radius);overflow:hidden;margin-top:30px;border:1px solid var(--line);z-index:0}

/* ---- careers ------------------------------------------------------------- */
.perk-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.perk{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;text-align:center;box-shadow:var(--shadow-sm)}
.perk .ic{width:56px;height:56px;border-radius:14px;background:linear-gradient(150deg,#eaf1fd,#dbe8fb);color:var(--blue);display:grid;place-items:center;margin:0 auto 14px}
.perk .ic svg{width:28px;height:28px}
.perk h4{color:var(--navy);font-size:1.04rem;margin-bottom:6px}
.perk p{font-size:.9rem;margin:0}
.jobs{display:grid;gap:16px;max-width:880px;margin:0 auto}
.job{display:flex;align-items:center;justify-content:space-between;gap:20px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px;box-shadow:var(--shadow-sm);transition:.2s}
.job:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.job h4{margin:0 0 6px;color:var(--navy);font-size:1.18rem}
.job .meta{display:flex;gap:16px;flex-wrap:wrap;font-size:.88rem;color:var(--muted)}
.job .meta span{display:inline-flex;align-items:center;gap:6px}
.job .meta svg{width:15px;height:15px;color:var(--blue)}

/* ---- prose (legal pages) ------------------------------------------------- */
.prose{max-width:820px;margin:0 auto}
.prose h2{color:var(--navy);font-size:1.5rem;margin-top:38px}
.prose h3{color:var(--navy);font-size:1.15rem;margin-top:26px}
.prose p,.prose li{color:var(--body)}
.prose ul{padding-left:20px}

/* ---- FAQ accordion ------------------------------------------------------- */
.faq-list{display:grid;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--head);font-weight:600;color:var(--navy);font-size:1.05rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-ic{display:inline-flex;color:var(--blue);transition:transform .25s;flex:0 0 auto}
.faq-ic svg{width:22px;height:22px}
.faq-item[open] .faq-ic{transform:rotate(180deg)}
.faq-item[open] summary{color:var(--blue)}
.faq-a{padding:0 24px 22px;color:var(--body);line-height:1.7}

/* ---- blog ---------------------------------------------------------------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s;display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow);transform:translateY(-6px)}
.blog-thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft)}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.blog-card:hover .blog-thumb img{transform:scale(1.06)}
.blog-cat{position:absolute;left:14px;top:14px;background:var(--red);color:#fff;font-family:var(--head);font-weight:600;font-size:.74rem;padding:5px 11px;border-radius:20px}
.blog-body{padding:22px 24px;display:flex;flex-direction:column;flex:1}
.blog-date{display:flex;align-items:center;gap:7px;font-size:.82rem;color:var(--muted);margin-bottom:8px}
.blog-date svg{width:15px;height:15px;color:var(--blue)}
.blog-body h3{color:var(--navy);font-size:1.18rem;margin-bottom:8px;line-height:1.3}
.blog-body p{font-size:.93rem;color:var(--body);flex:1}
.post-body p{margin:0 0 1.2rem;font-size:1.06rem;line-height:1.8;color:#374151}
.post-body h2{color:var(--navy);font-size:1.6rem;margin:32px 0 12px}
.post-body h3{color:var(--navy);font-size:1.3rem;margin:26px 0 10px}
.post-body ul,.post-body ol{padding-left:22px;margin-bottom:1.2rem}
.post-body li{margin-bottom:.5rem}
.post-body img{border-radius:14px}

/* ---- leaflet map pins ---------------------------------------------------- */
.bss-pin,.bss-end,.bss-cur{background:none;border:0}
.bss-pulse{position:absolute;left:50%;top:50%;width:40px;height:40px;border-radius:50%;background:rgba(225,27,34,.35);transform:translate(-50%,-50%);animation:bssPulse 1.8s ease-out infinite}
@keyframes bssPulse{0%{transform:translate(-50%,-50%) scale(.6);opacity:.7}100%{transform:translate(-50%,-50%) scale(2.4);opacity:0}}
.leaflet-container{font-family:var(--sans)}
.leaflet-popup-content-wrapper{border-radius:10px}
.leaflet-popup-content{font-size:.9rem;color:var(--ink)}

/* ---- reveal animation ---------------------------------------------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- responsive ---------------------------------------------------------- */
@media(max-width:1080px){
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .svc-grid .svc-card:nth-child(4),.svc-grid .svc-card:nth-child(5){grid-column:span 1}
  .footer-grid{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:960px){
  .header-cta{display:none}
  .nav-toggle{display:inline-flex}
  .main-nav{position:fixed;top:0;right:-320px;width:300px;max-width:84vw;height:100dvh;background:#fff;box-shadow:-10px 0 40px rgba(0,0,0,.16);padding:74px 20px 30px;transition:right .3s;z-index:120;overflow-y:auto}
  .main-nav.open{right:0}
  .main-nav>ul{flex-direction:column;align-items:stretch;gap:2px}
  .main-nav a{padding:13px 14px;font-size:1rem;border-radius:10px}
  .main-nav a.active::after{display:none}
  .nav-close{display:inline-flex;position:absolute;top:18px;right:18px}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:var(--bg-soft);margin:4px 0 6px;padding:4px}
  .has-dropdown:hover .caret{transform:none}
  .nav-cta-mobile{display:block;margin-top:14px}
  .nav-cta-mobile .btn{width:100%;justify-content:center}
  .nav-overlay.show{display:block;position:fixed;inset:0;background:rgba(8,18,40,.5);z-index:110}
  .why,.about-split,.svc-row,.svc-row.rev .svc-row-media,.contact-grid,.track-main{grid-template-columns:1fr}
  .svc-row.rev .svc-row-media{order:0}
  .track-main #trackMap{height:380px}
  .track-progress-wrap{max-height:none}
}
@media(max-width:820px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .stat:nth-child(2)::after{display:none}
  .tst-grid,.mvv-grid,.team-grid,.perk-grid{grid-template-columns:1fr}
  .track-summary{grid-template-columns:1fr 1fr}
  .track-summary .cell+.cell::before{display:none}
  .td-grid{grid-template-columns:1fr 1fr}
  .track-steps{grid-template-columns:1fr}
  .section{padding:64px 0}
  .hero{min-height:auto;padding:30px 0 0}
  .hero-inner{padding:46px 0 70px}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .form-grid,.svc-feat{grid-template-columns:1fr}
  .track-form{flex-direction:column}
  .track-form .field{padding:6px 12px}
  .track-form .btn{width:100%;justify-content:center}
  .track-summary{grid-template-columns:1fr}
  .td-grid{grid-template-columns:1fr}
  .track-docbar{flex-direction:column;align-items:flex-start;gap:16px}
  .track-barcode{align-self:stretch}
  .track-barcode .bars{height:40px;justify-content:center;overflow:hidden}
  .footer-grid{grid-template-columns:1fr}
  .cta-band-inner{flex-direction:column;text-align:center}
  .job{flex-direction:column;align-items:flex-start}
  .hero-trust{gap:14px 22px}
}
