/* ARTERIAL — shared design system for the RouteForgeX site */
:root{
  --ink:#0a111b;--ink2:#0c1724;--panel:#0f1d2e;--line:#1d2f45;--line2:#26405d;
  --steel:#5c7088;--steel2:#3a516c;--bone:#e9eef5;--mut:#7e90a8;
  --amb:#ff8a1e;--amb2:#ffb256;--grn:#39c08a;
  --mono:"IBM Plex Mono",monospace;--disp:"Archivo",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ink);color:var(--bone);font-family:var(--disp);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono)}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
.ey{font-family:var(--mono);font-size:11.5px;letter-spacing:.32em;color:var(--amb)}
.amb{color:var(--amb)}
.demo-only{display:none!important}

/* ── header ── */
header.site{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;background:rgba(10,17,27,.82);backdrop-filter:blur(8px)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.16em;font-size:16px}
.logo .mk{width:30px;height:30px;border:1px solid var(--amb);display:flex;align-items:center;justify-content:center}
.logo .mk svg{width:16px;height:16px}
.logo .dot{color:var(--amb)}
header.site nav{display:flex;gap:30px;font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--mut)}
header.site nav a:hover{color:var(--bone)}
header.site nav a.on{color:var(--amb)}
.htrack{font-family:var(--mono);font-size:12px;letter-spacing:.14em;border:1px solid var(--line2);padding:10px 18px;color:var(--bone)}
.htrack:hover{border-color:var(--amb);color:var(--amb)}

/* ── homepage hero ── */
.hero{position:relative;border-bottom:1px solid var(--line);overflow:hidden;background:radial-gradient(1100px 520px at 80% -10%,#11233a 0,transparent 60%),var(--ink)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(transparent 95%,rgba(38,64,93,.45) 95%),linear-gradient(90deg,transparent 95%,rgba(38,64,93,.45) 95%);background-size:46px 46px;opacity:.4;-webkit-mask-image:radial-gradient(800px 460px at 78% 35%,#000,transparent 72%);mask-image:radial-gradient(800px 460px at 78% 35%,#000,transparent 72%)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:center;padding:78px 32px 84px}
.hero h1{font-size:clamp(40px,5.4vw,68px);font-weight:900;letter-spacing:-.03em;line-height:.97;margin:18px 0 18px}
.hero h1 em{font-style:normal;color:var(--amb)}
.hero p{color:var(--mut);font-size:17px;max-width:430px;margin:0 0 32px}
.cta{display:flex;gap:14px;flex-wrap:wrap}
.heromap{position:relative}.heromap svg{width:100%;height:auto;display:block}

/* ── inner-page hero ── */
.phero{position:relative;border-bottom:1px solid var(--line);overflow:hidden;background:radial-gradient(900px 360px at 80% -40px,#11233a 0,transparent 60%),var(--ink)}
.phero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(transparent 95%,rgba(38,64,93,.4) 95%),linear-gradient(90deg,transparent 95%,rgba(38,64,93,.4) 95%);background-size:46px 46px;opacity:.35;-webkit-mask-image:radial-gradient(760px 360px at 75% 40%,#000,transparent 72%);mask-image:radial-gradient(760px 360px at 75% 40%,#000,transparent 72%)}
.phero .wrap{position:relative;padding:64px 32px 58px}
.phero h1{font-size:clamp(34px,5vw,56px);font-weight:900;letter-spacing:-.028em;line-height:1;margin:16px 0 16px;max-width:780px}
.phero p{color:var(--mut);font-size:17px;max-width:560px;margin:0}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--steel)}

/* ── buttons ── */
.btn{display:inline-block;font-family:var(--disp);font-weight:700;font-size:14px;letter-spacing:.03em;padding:15px 30px;cursor:pointer;border:1px solid transparent}
.btn.p{background:var(--amb);color:#10151c}.btn.p:hover{background:var(--amb2)}
.btn.s{border-color:var(--line2);color:var(--bone)}.btn.s:hover{border-color:var(--steel)}

/* ── sections ── */
section{padding:88px 0;border-bottom:1px solid var(--line)}
.shead{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:24px}
.shead h2{font-size:clamp(28px,3.4vw,42px);font-weight:800;letter-spacing:-.02em;margin:12px 0 0;max-width:640px}
.shead p{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--mut);max-width:300px;text-align:right}

/* ── services grid (homepage) ── */
.svc{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.svc .it{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:34px 30px 38px;transition:.2s;position:relative}
.svc .it:hover{background:var(--ink2)}
.svc .it .code{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--amb)}
.svc .it h3{font-size:21px;font-weight:700;margin:16px 0 12px;letter-spacing:-.01em}
.svc .it p{color:var(--mut);font-size:14px;margin:0}
.svc .it .ar{position:absolute;top:34px;right:30px;color:var(--steel2);font-family:var(--mono)}

/* ── network section (homepage) ── */
.net{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.net .map svg{width:100%;height:auto}
.net .copy h2{font-size:clamp(28px,3.2vw,40px);font-weight:800;letter-spacing:-.02em;margin:14px 0 18px}
.net .copy p{color:var(--mut);font-size:15.5px;max-width:440px}
.netstats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:34px}
.netstats div{background:var(--ink);padding:20px 22px}
.netstats .n{font-family:var(--mono);font-size:22px;color:var(--bone)}.netstats .n b{color:var(--amb);font-weight:500}
.netstats .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--steel);margin-top:6px;text-transform:uppercase}

/* ── night-ops timeline (homepage) ── */
.flow{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line);position:relative;margin-top:14px}
.flow::after{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,var(--amb),transparent 85%)}
.flow .st{padding:28px 22px 30px;border-right:1px solid var(--line)}.flow .st:last-child{border-right:none}
.flow .st .tm{font-family:var(--mono);font-size:12px;color:var(--amb);letter-spacing:.1em}
.flow .st h4{font-size:16px;font-weight:700;margin:14px 0 8px}
.flow .st p{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--mut);margin:0;line-height:1.6}

/* ── track band (homepage) ── */
.band{padding:72px 0;text-align:center;background:radial-gradient(700px 280px at 50% 0,#11233a 0,transparent 70%),var(--ink2)}
.band h2{font-size:clamp(26px,3vw,38px);font-weight:800;letter-spacing:-.02em;margin:14px 0 26px}
.band form{display:flex;max-width:560px;margin:0 auto;border:1px solid var(--line2);background:var(--ink)}
.band input{flex:1;border:none;background:transparent;color:var(--bone);font-family:var(--mono);font-size:14px;letter-spacing:.06em;padding:17px 20px}
.band input:focus{outline:none}.band input::placeholder{color:var(--steel2)}
.band button{border:none;background:var(--amb);color:#10151c;font-weight:700;font-size:14px;padding:0 32px;cursor:pointer}.band button:hover{background:var(--amb2)}

/* ── stat strip ── */
.stats{border-bottom:1px solid var(--line);background:var(--ink2)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:30px 0 30px 28px;border-left:1px solid var(--line)}.stat:first-child{border-left:none;padding-left:0}
.stat .n{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.01em;color:var(--bone)}.stat .n b{color:var(--amb);font-weight:500}
.stat .l{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--steel);margin-top:8px;text-transform:uppercase}

/* ── prose (legal / about) ── */
.prose{max-width:760px}
.prose h2{font-size:24px;font-weight:800;letter-spacing:-.015em;margin:42px 0 14px}
.prose h3{font-size:17px;font-weight:700;margin:30px 0 10px;color:var(--bone)}
.prose p,.prose li{color:var(--mut);font-size:15.5px;line-height:1.75}
.prose ul{padding-left:20px;margin:0 0 18px}.prose li{margin-bottom:8px}
.prose strong{color:var(--bone);font-weight:600}
.prose a{color:var(--amb2);border-bottom:1px solid var(--steel2)}
.prose .updated{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;color:var(--steel);margin-bottom:8px}
.prose .lead{font-size:17px;color:var(--bone)}

/* ── bordered cell grids ── */
.cells{display:grid;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.cells.c3{grid-template-columns:repeat(3,1fr)}.cells.c2{grid-template-columns:repeat(2,1fr)}.cells.c4{grid-template-columns:repeat(4,1fr)}
.cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 28px 36px;position:relative;transition:.2s}
.cell:hover{background:var(--ink2)}
.cell .code{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--amb)}
.cell h3{font-size:20px;font-weight:700;margin:15px 0 11px;letter-spacing:-.01em}
.cell p{color:var(--mut);font-size:14px;margin:0}
.cell .ar{position:absolute;top:32px;right:28px;color:var(--steel2);font-family:var(--mono)}

/* ── faq accordion ── */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;font-size:17px;font-weight:600}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--amb);font-size:22px;font-weight:400}
.faq details[open] summary::after{content:"\2212"}
.faq .a{color:var(--mut);font-size:15px;line-height:1.7;padding:0 40px 26px 0;max-width:760px}

/* ── contact form ── */
.form{display:grid;gap:16px;max-width:560px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--steel);display:block;margin-bottom:7px;text-transform:uppercase}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--line2);background:var(--ink2);color:var(--bone);font-family:var(--disp);font-size:15px;padding:13px 15px}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--amb)}
.form textarea{min-height:130px;resize:vertical}

/* ── contact cards ── */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.contact-grid>div{background:var(--ink);padding:24px}
.contact-grid .k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--steel);text-transform:uppercase}
.contact-grid .v{font-size:15px;margin-top:10px;line-height:1.6}.contact-grid .v a{color:var(--amb2)}

/* ── shipments table ── */
.tablewrap{border:1px solid var(--line);overflow:hidden}
table.sh{width:100%;border-collapse:collapse}
table.sh th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--steel);text-transform:uppercase;padding:15px 22px;background:var(--ink2);border-bottom:1px solid var(--line)}
table.sh td{padding:17px 22px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
table.sh tr:last-child td{border-bottom:none}
table.sh .tn{font-family:var(--mono);letter-spacing:.04em}
table.sh .sub{font-size:12px;color:var(--mut);margin-top:3px}
.chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;padding:6px 12px;border:1px solid var(--line2);color:var(--bone);white-space:nowrap}
.chip .d{width:7px;height:7px;border-radius:50%;background:var(--steel)}
.chip.s-transit{border-color:#2b4d7a;color:#9cc2ff}.chip.s-transit .d{background:#4f8bff}
.chip.s-customs{border-color:#6b4e1c;color:var(--amb2)}.chip.s-customs .d{background:var(--amb)}
.chip.s-out{border-color:#2f6b53;color:#6fe3b4}.chip.s-out .d{background:var(--grn)}
.chip.s-delivered{border-color:#2f6b53;color:#6fe3b4}.chip.s-delivered .d{background:var(--grn)}
.chip.s-info{border-color:var(--line2);color:var(--mut)}.chip.s-info .d{background:var(--steel)}
.pbar{width:120px;height:6px;background:var(--line);overflow:hidden}.pbar i{display:block;height:100%;background:var(--amb)}
.tlink{color:var(--amb);font-family:var(--mono);font-size:12px;letter-spacing:.08em}

/* ── footer ── */
footer.site{padding:64px 0 30px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding-bottom:46px;border-bottom:1px solid var(--line)}
.fgrid .b p{color:var(--mut);font-size:13.5px;max-width:280px;margin:16px 0 0}
.fgrid h5{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--steel);margin:0 0 18px;text-transform:uppercase}
.fgrid ul{list-style:none;margin:0;padding:0}.fgrid li{margin-bottom:11px}.fgrid a{color:var(--mut);font-size:14px}.fgrid a:hover{color:var(--bone)}
.fbot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--steel)}

/* ── responsive ── */
@media(max-width:900px){
  header.site nav{display:none}
  .hero .wrap{grid-template-columns:1fr}.heromap{display:none}
  .svc,.flow{grid-template-columns:1fr 1fr}
  .cells.c3,.cells.c4{grid-template-columns:1fr 1fr}
  .stats .wrap{grid-template-columns:1fr 1fr}
  .net{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .form .row{grid-template-columns:1fr}
}
