/* ============================================================
   TLS — Target Logistics Solution  |  powered by CargoETL
   Global design system. Dark premium / logistics-tech.
   ============================================================ */
:root{
  /* surfaces */
  --bg:#070A12;
  --bg-1:#0B0E18;
  --bg-2:#111726;
  --panel:#131A2A;
  --panel-2:#18202F;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  /* brand accents (teal+blue from logo) */
  --teal:#2DD4BF;
  --teal-2:#5EEAD4;
  --blue:#3B82F6;
  --blue-2:#60A5FA;
  --grad:linear-gradient(120deg,#2DD4BF 0%,#3B82F6 100%);
  --grad-soft:linear-gradient(120deg,rgba(45,212,191,.16),rgba(59,130,246,.16));
  /* text */
  --tx:#F4F7FB;
  --tx-mut:#9FB0C6;
  --tx-dim:#6B7C95;
  /* effects */
  --glow-teal:0 0 60px rgba(45,212,191,.18);
  --glow-blue:0 0 60px rgba(59,130,246,.16);
  --shadow:0 24px 60px -20px rgba(0,0,0,.7);
  --r:18px; --r-sm:12px; --r-lg:26px;
  --maxw:1200px;
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);background:var(--bg);color:var(--tx);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
/* ambient background glows */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(800px 500px at 12% -5%,rgba(45,212,191,.10),transparent 60%),
    radial-gradient(900px 600px at 95% 8%,rgba(59,130,246,.10),transparent 60%),
    radial-gradient(700px 600px at 50% 120%,rgba(59,130,246,.07),transparent 60%);
}
body::after{ /* subtle grid */
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;mask:radial-gradient(circle at 50% 0%,#000,transparent 75%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}

/* ---------- Typography ---------- */
h1,h2,h3{line-height:1.08;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.4rem,6vw,4.3rem)}
h2{font-size:clamp(1.9rem,4vw,2.9rem)}
h3{font-size:1.3rem;font-weight:700}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--teal-2);
  padding:7px 14px;border:1px solid var(--line-2);border-radius:100px;
  background:var(--grad-soft);backdrop-filter:blur(6px);
}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--tx-mut);max-width:60ch}
.gradient-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:.97rem;padding:15px 26px;border-radius:100px;
  border:1px solid transparent;cursor:pointer;transition:.22s ease;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--grad);color:#04121A;box-shadow:0 10px 30px -8px rgba(45,212,191,.5)}
.btn-primary:hover{box-shadow:0 16px 40px -8px rgba(45,212,191,.65)}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--tx);border-color:var(--line-2)}
.btn-ghost:hover{background:rgba(255,255,255,.09);border-color:var(--teal)}
.btn-lg{padding:18px 34px;font-size:1.05rem}
.btn .ar{transition:transform .22s}.btn:hover .ar{transform:translateX(4px)}

/* ---------- Nav ---------- */
header.nav{position:sticky;top:0;z-index:50;transition:.3s}
header.nav.scrolled{background:rgba(7,10,18,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.brand .logo{width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center;color:#04121A;font-weight:900;box-shadow:var(--glow-teal)}
.brand small{display:block;font-size:.6rem;font-weight:600;letter-spacing:.12em;color:var(--tx-dim);text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:.93rem;color:var(--tx-mut);font-weight:500;transition:.2s;position:relative}
.nav-links a:hover{color:var(--tx)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--grad);transition:.25s}
.nav-links a:hover::after{width:100%}
.nav-links .mobile-cta{display:none}
.nav-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--tx);border-radius:2px;transition:.25s}

/* ---------- Hero ---------- */
.hero{padding:72px 0 90px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin:20px 0 22px}
.hero .lead{margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-proof{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.hero-proof div{display:flex;flex-direction:column}
.hero-proof b{font-size:1.7rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-proof span{font-size:.82rem;color:var(--tx-dim)}
/* hero visual = live map card */
.map-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-2);
  background:var(--panel);box-shadow:var(--shadow),var(--glow-blue);
}
.map-card img{width:100%;height:auto;display:block}
.map-card .topbar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line);background:rgba(7,10,18,.6)}
.map-card .dot{width:11px;height:11px;border-radius:50%}
.map-card .live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-size:.76rem;color:var(--teal-2);font-weight:700}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(45,212,191,.7);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 12px rgba(45,212,191,0)}100%{box-shadow:0 0 0 0 rgba(45,212,191,0)}}
.map-overlay{position:absolute;left:16px;bottom:16px;right:16px;display:flex;gap:10px}
.map-chip{flex:1;background:rgba(11,14,24,.82);backdrop-filter:blur(10px);border:1px solid var(--line-2);border-radius:14px;padding:12px 14px}
.map-chip b{display:block;font-size:1.35rem;font-weight:800;color:var(--teal-2)}
.map-chip span{font-size:.72rem;color:var(--tx-dim)}

/* ---------- Section header ---------- */
.sec{padding:90px 0}
.sec-head{max-width:660px;margin-bottom:52px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{margin:16px 0 14px}

/* ---------- Logos / trust strip ---------- */
.strip{border-block:1px solid var(--line);padding:26px 0;background:rgba(255,255,255,.015)}
.strip-in{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.strip-item{display:flex;align-items:center;gap:11px;color:var(--tx-mut);font-size:.9rem;font-weight:600}
.strip-item svg{color:var(--teal)}

/* ---------- Audience fork ---------- */
.fork{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fork-card{
  position:relative;padding:32px 28px 28px;border-radius:var(--r);border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--bg-1));overflow:hidden;transition:.28s;
}
.fork-card::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:.28s}
.fork-card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:var(--shadow)}
.fork-card:hover::before{opacity:1}
.fork-card>*{position:relative}
.fork-ic{width:52px;height:52px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--line-2);display:grid;place-items:center;color:var(--teal-2);margin-bottom:18px}
.fork-card h3{margin-bottom:9px}
.fork-card p{color:var(--tx-mut);font-size:.95rem;margin-bottom:20px}
.fork-card .lnk{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--teal-2);font-size:.92rem}
.fork-card .lnk .ar{transition:.2s}.fork-card:hover .lnk .ar{transform:translateX(5px)}

/* ---------- Feature grid ---------- */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat-card{padding:28px 26px;border-radius:var(--r);border:1px solid var(--line);background:var(--panel);transition:.25s}
.feat-card:hover{transform:translateY(-5px);border-color:var(--line-2);box-shadow:var(--shadow)}
.feat-ic{width:48px;height:48px;border-radius:13px;background:var(--grad-soft);display:grid;place-items:center;color:var(--teal-2);margin-bottom:16px;border:1px solid var(--line-2)}
.feat-card h3{font-size:1.12rem;margin-bottom:8px}
.feat-card p{color:var(--tx-mut);font-size:.92rem}

/* ---------- Split feature (text + visual) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split.rev .split-txt{order:2}
.split-txt h2{margin:14px 0 16px}
.split-txt .lead{margin-bottom:24px}
.checklist{list-style:none;display:grid;gap:13px;margin-bottom:28px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--tx);font-size:.97rem}
.checklist .ck{flex:none;width:24px;height:24px;border-radius:8px;background:var(--grad-soft);border:1px solid var(--line-2);display:grid;place-items:center;color:var(--teal-2);margin-top:1px}
.visual-frame{border-radius:var(--r-lg);border:1px solid var(--line-2);background:var(--panel);box-shadow:var(--shadow),var(--glow-teal);overflow:hidden}
.visual-frame img{width:100%}

/* ---------- AI assistant mock ---------- */
.ai-mock{padding:22px;background:linear-gradient(180deg,var(--panel-2),var(--bg-1));border-radius:var(--r-lg);border:1px solid var(--line-2);box-shadow:var(--shadow),var(--glow-teal)}
.ai-head{display:flex;align-items:center;gap:11px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:16px}
.ai-head .av{width:36px;height:36px;border-radius:10px;background:var(--grad);display:grid;place-items:center;color:#04121A;font-weight:900}
.ai-head b{font-size:.95rem}.ai-head span{font-size:.72rem;color:var(--teal-2);display:block;font-weight:700}
.bubble{padding:13px 16px;border-radius:14px;margin-bottom:12px;font-size:.92rem;max-width:88%}
.bubble.me{background:var(--grad-soft);border:1px solid var(--line-2);margin-left:auto;border-bottom-right-radius:4px}
.bubble.ai{background:rgba(255,255,255,.04);border:1px solid var(--line);border-bottom-left-radius:4px;color:var(--tx-mut)}
.ai-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.ai-chip{font-size:.78rem;padding:8px 13px;border-radius:100px;border:1px solid var(--line-2);background:rgba(255,255,255,.03);color:var(--tx-mut)}

/* ---------- App showcase ---------- */
.app-gallery{display:flex;gap:18px;overflow-x:auto;padding:8px 4px 22px;scroll-snap-type:x mandatory}
.phone{flex:none;width:240px;scroll-snap-align:center;border-radius:30px;overflow:hidden;border:1px solid var(--line-2);background:#0a1020;box-shadow:var(--shadow);transition:.3s}
.phone:hover{transform:translateY(-8px)}
.phone img{width:100%;display:block}
.app-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:10px}
.app-badge{display:inline-flex;align-items:center;gap:11px;padding:12px 22px;border-radius:14px;border:1px solid var(--line-2);background:#000;color:#fff;font-weight:600}
.app-badge small{display:block;font-size:.62rem;color:#bbb}.app-badge b{font-size:1.05rem}
.app-icon{width:62px;height:62px;border-radius:15px;box-shadow:var(--glow-teal)}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.stat b{display:block;font-size:clamp(2rem,4vw,3.1rem);font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.03em}
.stat span{color:var(--tx-mut);font-size:.9rem;font-weight:500}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:s}
.step{position:relative;padding:30px 26px;border-radius:var(--r);border:1px solid var(--line);background:var(--panel)}
.step::before{counter-increment:s;content:"0" counter(s);position:absolute;top:22px;right:24px;font-size:2.4rem;font-weight:800;opacity:.12}
.step h3{margin:8px 0 8px;font-size:1.1rem}
.step p{color:var(--tx-mut);font-size:.92rem}

/* ---------- CTA band ---------- */
.cta-band{margin:0 24px;border-radius:var(--r-lg);background:var(--grad);padding:62px 40px;text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% -40%,rgba(255,255,255,.35),transparent)}
.cta-band>*{position:relative;color:#04121A}
.cta-band h2{color:#04121A;margin-bottom:14px}
.cta-band p{color:#073B40;max-width:54ch;margin:0 auto 28px;font-weight:500}
.cta-band .btn-primary{background:#04121A;color:#fff;box-shadow:0 14px 40px -10px rgba(0,0,0,.5)}
.cta-band .btn-ghost{background:rgba(4,18,26,.12);border-color:rgba(4,18,26,.3);color:#04121A}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{padding:28px 26px;border-radius:var(--r);border:1px solid var(--line);background:var(--panel)}
.quote .stars{color:#FBBF24;margin-bottom:12px;letter-spacing:2px}
.quote p{color:var(--tx);font-size:.96rem;margin-bottom:18px}
.quote .who{display:flex;align-items:center;gap:11px}
.quote .who .ava{width:38px;height:38px;border-radius:50%;background:var(--grad-soft);border:1px solid var(--line-2);display:grid;place-items:center;font-weight:700;color:var(--teal-2)}
.quote .who b{font-size:.9rem}.quote .who span{font-size:.78rem;color:var(--tx-dim)}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);padding:60px 0 30px;margin-top:90px;background:rgba(255,255,255,.012)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;margin-bottom:44px}
.foot-grid h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--tx-dim);margin-bottom:16px}
.foot-grid a{display:block;color:var(--tx-mut);font-size:.92rem;margin-bottom:10px;transition:.2s}
.foot-grid a:hover{color:var(--teal-2)}
.foot-about p{color:var(--tx-mut);font-size:.92rem;margin:14px 0;max-width:34ch}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line);color:var(--tx-dim);font-size:.84rem}
.powered{display:inline-flex;align-items:center;gap:7px;color:var(--tx-mut)}
.powered b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{padding:70px 0 50px;text-align:center}
.page-hero h1{font-size:clamp(2.1rem,5vw,3.4rem);margin:18px auto 16px}
.page-hero .lead{margin-inline:auto}

/* ---------- Embed frame ---------- */
.embed{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow),var(--glow-blue);background:var(--panel);height:640px}
.embed iframe{width:100%;height:100%;border:0;display:block}

/* ---------- Forms ---------- */
.form{display:grid;gap:16px;max-width:560px}
.field{display:grid;gap:7px}
.field label{font-size:.85rem;color:var(--tx-mut);font-weight:600}
.field input,.field select,.field textarea{
  background:var(--panel);border:1px solid var(--line-2);border-radius:12px;padding:13px 15px;color:var(--tx);font-family:inherit;font-size:.95rem;transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--teal);box-shadow:0 0 0 3px rgba(45,212,191,.15)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid,.split,.foot-grid{grid-template-columns:1fr;gap:38px}
  .split.rev .split-txt{order:0}
  .fork,.feat,.steps,.quotes{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-cta{display:none}
  .burger{display:flex}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;background:rgba(7,10,18,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:10px 24px 22px}
  .nav-links.open a{padding:14px 0;border-bottom:1px solid var(--line);width:100%}
  .nav-links.open .mobile-cta{display:block;margin-top:10px;border:0;text-align:center;padding:15px;border-radius:100px;font-weight:700;background:var(--grad);color:#04121A}
  .nav-links.open .mobile-cta:last-child{background:rgba(255,255,255,.06);color:var(--tx);border:1px solid var(--line-2)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .fork,.feat,.steps,.quotes,.grid-2{grid-template-columns:1fr}
  .hero-proof{gap:20px}
  .cta-band{padding:44px 24px;margin:0 16px}
  .embed{height:520px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.fork-card:hover,.feat-card:hover,.phone:hover{transform:none}
}
