/* ============================================================
   Triple E Trucking LLC — Site Styles
   Aesthetic: rugged but polished. Subtle motion.
   ============================================================ */

:root{
  --navy:#022e8f;        /* logo royal blue */
  --navy-deep:#011c58;   /* derived deep blue */
  --navy-mid:#0a3aad;    /* brighter mid blue */
  --red:#d91b24;         /* logo red */
  --red-bright:#f02630;
  --red-dark:#a8121a;
  --white:#ffffff;
  --bg:#eef2f9;
  --bg-warm:#e8eef7;
  --ink:#15203a;
  --muted:#566080;
  --line:#d4ddec;
  --steel:#8b97b5;
  --gold:#d9a441;
  --radius:4px;
  --shadow-sm:0 2px 8px rgba(2,46,143,.08);
  --shadow:0 18px 50px rgba(1,28,88,.16);
  --shadow-lg:0 30px 80px rgba(1,28,88,.28);
  --maxw:1200px;
  --ease:cubic-bezier(.16,.84,.44,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Archivo","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:"Oswald","Saira Condensed",sans-serif;
  font-weight:600;line-height:1.05;color:var(--navy);
  letter-spacing:.5px;text-transform:uppercase;
}
h1{font-size:clamp(2.6rem,6.5vw,5rem);font-weight:700;letter-spacing:1px}
h2{font-size:clamp(2rem,4.5vw,3.2rem)}
h3{font-size:1.4rem;letter-spacing:.6px}
p{font-size:1.02rem}
a{color:var(--red);text-decoration:none;transition:color .2s}
a:hover{color:var(--red-dark)}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:100px 0;position:relative}
.center{text-align:center}
.muted{color:var(--muted)}
.lead{font-size:1.2rem;color:var(--muted);max-width:64ch;line-height:1.7}
.lead.center{margin-left:auto;margin-right:auto}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--red);font-weight:700;letter-spacing:3px;
  text-transform:uppercase;font-size:.82rem;margin-bottom:18px;
}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--red);display:inline-block}
.eyebrow.light{color:#ff6b6b}
.eyebrow.light::before{background:#ff6b6b}
.eyebrow.center{justify-content:center}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--red);color:#fff;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;font-size:.9rem;
  padding:16px 36px;border:none;cursor:pointer;border-radius:var(--radius);
  position:relative;overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s;
  box-shadow:0 8px 24px rgba(204,0,0,.32);font-family:"Archivo",sans-serif;
}
.btn::after{content:"\2192";font-size:1.1rem;transition:transform .25s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(204,0,0,.42);color:#fff}
.btn:hover::after{transform:translateX(5px)}
.btn-ghost{background:transparent;border:2px solid rgba(255,255,255,.55);box-shadow:none;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff;box-shadow:0 14px 34px rgba(0,0,0,.2)}
.btn-light{background:#fff;color:var(--red);box-shadow:0 10px 30px rgba(0,0,0,.18)}
.btn-light:hover{color:var(--red-dark)}

/* ---------- Header (white, logo-friendly) ---------- */
header{
  position:sticky;top:0;z-index:100;
  background:#fff;
  border-bottom:1px solid var(--line);
  box-shadow:0 2px 14px rgba(5,16,46,.07);
  transition:box-shadow .3s;
}
.nav{display:flex;align-items:center;justify-content:space-between;height:92px}
.brand{display:flex;align-items:center;gap:14px;color:var(--navy);font-family:"Oswald",sans-serif;font-weight:700;font-size:1.55rem;letter-spacing:1.5px;text-transform:uppercase}
.brand:hover{color:var(--navy)}
.brand-logo{height:62px;width:auto;display:block}
.navlinks{display:flex;gap:34px;align-items:center}
.navlinks a{color:var(--navy);font-weight:600;text-transform:uppercase;font-size:.88rem;letter-spacing:1px;position:relative;padding:4px 0}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .28s var(--ease)}
.navlinks a:hover,.navlinks a.active{color:var(--red)}
.navlinks a:hover::after,.navlinks a.active::after{width:100%}
.nav-cta{background:var(--red);color:#fff !important;padding:11px 24px;border-radius:var(--radius);letter-spacing:1px}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--red-bright);transform:translateY(-2px);box-shadow:0 8px 20px rgba(204,0,0,.4)}
.menu-btn{display:none;background:none;border:none;color:var(--navy);font-size:1.7rem;cursor:pointer}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;background:var(--navy-deep);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  /* Drop a hero photo at images/hero.jpg to replace gradient */
  background:
    linear-gradient(105deg,rgba(5,16,46,.97) 0%,rgba(5,16,46,.82) 45%,rgba(10,31,92,.55) 100%),
    var(--navy-deep);
  background-size:cover;background-position:center;
}
.hero-bg.has-photo{
  background:
    linear-gradient(105deg,rgba(5,16,46,.94) 0%,rgba(5,16,46,.74) 45%,rgba(10,31,92,.45) 100%),
    url("images/hero.jpg");
  background-size:cover;background-position:center;
}
/* subtle texture grid overlay */
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60M59 0v60' stroke='%23ffffff' stroke-opacity='0.035' stroke-width='1'/%3E%3C/svg%3E");
}
.hero .container{position:relative;z-index:2}
.hero-inner{max-width:760px}
.hero h1{color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.hero h1 .hl{color:#fff;position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.16em;background:var(--red);z-index:-1}
.hero p{font-size:1.25rem;max-width:56ch;margin:26px 0 38px;color:#dde3f2;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
/* corner accent */
.hero-tag{position:absolute;right:-1px;top:50%;transform:translateY(-50%);z-index:2;writing-mode:vertical-rl;font-family:"Oswald",sans-serif;font-weight:700;letter-spacing:6px;text-transform:uppercase;color:rgba(255,255,255,.08);font-size:1.4rem}

/* diagonal red stripe accent bar */
.stripe{height:7px;background:linear-gradient(90deg,var(--red) 0 34%,#fff 34% 50%,var(--navy-mid) 50% 100%);position:relative;z-index:3}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}.reveal.d6{transition-delay:.48s}

/* ---------- Section heading block ---------- */
.head-block{max-width:62ch;margin-bottom:54px}
.head-block.center{margin-left:auto;margin-right:auto;text-align:center}
.head-block h2{margin-bottom:16px}

/* ---------- Cards / service grid ---------- */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:0;box-shadow:var(--shadow-sm);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  position:relative;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:#c2cce0}
/* service card with image slot */
.svc-img{
  height:200px;background:linear-gradient(135deg,var(--navy),var(--navy-mid));
  position:relative;overflow:hidden;display:grid;place-items:center;
}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .svc-img img{transform:scale(1.06)}
.svc-img .ph{font-family:"Oswald",sans-serif;font-size:3.4rem;font-weight:700;color:rgba(255,255,255,.18);letter-spacing:-2px}
.svc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(5,16,46,.4),transparent 60%)}
.svc-tag{position:absolute;top:14px;left:14px;z-index:2;background:var(--red);color:#fff;font-family:"Oswald",sans-serif;font-weight:700;font-size:.78rem;letter-spacing:1.5px;padding:5px 12px;border-radius:3px}
.card-body{padding:28px 30px 32px}
.card-body h3{color:var(--navy);margin-bottom:10px}
.card-body p{color:var(--muted);font-size:.98rem}

/* plain icon card (no image) */
.card.plain{padding:34px 32px}
.card.plain .ic{
  width:58px;height:58px;border-radius:8px;
  background:linear-gradient(135deg,var(--navy),var(--navy-mid));
  color:#fff;display:grid;place-items:center;font-weight:800;
  font-family:"Oswald",sans-serif;font-size:1.3rem;margin-bottom:18px;
  letter-spacing:-1px;box-shadow:0 8px 20px rgba(10,31,92,.3);
}

/* ---------- Stats band ---------- */
.band{position:relative;background:var(--navy-deep);color:#fff;padding:90px 0;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60M59 0v60' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='1'/%3E%3C/svg%3E")}
.band .container{position:relative;z-index:1}
.band h2{color:#fff}
.band.red{background:linear-gradient(135deg,var(--red),var(--red-dark))}
.band.red::before{opacity:.4}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat{text-align:center;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:15%;height:70%;width:1px;background:rgba(255,255,255,.14)}
.stat .num{font-family:"Oswald",sans-serif;font-size:3.6rem;font-weight:700;color:#fff;line-height:1}
.stat .num .accent{color:var(--red-bright)}
.band.red .stat .num .accent{color:#fff}
.stat .lbl{display:block;margin-top:12px;text-transform:uppercase;letter-spacing:1.5px;font-size:.82rem;color:var(--steel)}
.band.red .stat .lbl{color:#ffd6d6}

/* ---------- Split feature (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.rev .split-media{order:2}
.split-media{
  position:relative;border-radius:var(--radius);overflow:hidden;
  min-height:440px;box-shadow:var(--shadow);
  background:linear-gradient(135deg,var(--navy),var(--navy-mid));
  display:grid;place-items:center;
}
.split-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.split-media .ph{font-family:"Oswald",sans-serif;color:rgba(255,255,255,.16);font-size:1.1rem;letter-spacing:3px;text-align:center;padding:20px;z-index:1}
.split-media::after{content:"";position:absolute;left:0;bottom:0;width:90px;height:90px;background:var(--red);clip-path:polygon(0 100%,100% 100%,0 0);z-index:2}

/* ---------- Customers ---------- */
.cust{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.cust span{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 40px;font-weight:700;color:var(--navy);
  font-family:"Oswald",sans-serif;font-size:1.4rem;letter-spacing:1px;
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s;
}
.cust span:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:var(--red)}

/* ---------- Materials grid ---------- */
.materials{display:flex;flex-wrap:wrap;gap:14px}
.materials span{
  background:#fff;border:1px solid var(--line);border-left:4px solid var(--red);
  border-radius:var(--radius);padding:14px 22px;font-weight:600;color:var(--navy);
  font-size:1.02rem;box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;
}
.materials span:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-left-color:var(--navy)}

/* ---------- Partners ---------- */
.partners{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.partners .partner{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 42px;font-weight:700;color:var(--navy);
  font-family:"Oswald",sans-serif;font-size:1.35rem;letter-spacing:1px;
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s,color .3s;
  display:inline-flex;align-items:center;text-decoration:none;
}
.partners a.partner:hover{transform:translateY(-4px);box-shadow:var(--shadow);color:var(--red)}
.partners a.partner::after{content:"\2197";font-size:.85rem;margin-left:8px;opacity:.5}

/* ---------- Page header band ---------- */
.pagehead{position:relative;background:var(--navy-deep);color:#fff;padding:96px 0 88px;overflow:hidden}
.pagehead::before{content:"";position:absolute;inset:0;background:
  linear-gradient(105deg,rgba(5,16,46,.96),rgba(10,31,92,.7)),
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60M59 0v60' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='1'/%3E%3C/svg%3E")}
.pagehead .container{position:relative;z-index:1}
.pagehead h1{color:#fff}
.pagehead p{color:#cfd6ea;font-size:1.18rem;margin-top:14px;max-width:62ch}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px}
.info-row{display:flex;gap:18px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.info-row .ic{flex:0 0 auto;width:48px;height:48px;border-radius:8px;background:linear-gradient(135deg,var(--red-bright),var(--red-dark));color:#fff;display:grid;place-items:center;font-size:1.2rem;box-shadow:0 6px 16px rgba(204,0,0,.3)}
.info-row b{display:block;color:var(--muted);text-transform:uppercase;font-size:.74rem;letter-spacing:1.5px;margin-bottom:2px}
.info-row .val{font-size:1.1rem;color:var(--navy);font-weight:600}
.info-row .val a{color:var(--navy)}
.info-row .val a:hover{color:var(--red)}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow)}
.form-card.dark{background:var(--navy);color:#fff;border:none}
form label{display:block;font-weight:600;color:var(--navy);margin:16px 0 6px;font-size:.82rem;text-transform:uppercase;letter-spacing:1px}
.form-card.dark label{color:#cfd6ea}
form input,form textarea,form select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius);font:inherit;background:#fbfcfe;transition:border-color .2s,box-shadow .2s}
form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(10,31,92,.12)}
.form-note{font-size:.82rem;color:var(--muted);margin-top:14px}
.form-card.dark .form-note{color:var(--steel)}

/* ---------- About glance card ---------- */
.glance{background:linear-gradient(135deg,var(--navy),var(--navy-deep));color:#fff;border-radius:var(--radius);padding:40px;box-shadow:var(--shadow)}
.glance h3{color:#fff;margin-bottom:8px}
.glance .info-row{border-color:rgba(255,255,255,.12)}
.glance .info-row b{color:#ff8a8a}
.glance .info-row .val{color:#fff}

/* ---------- Footer ---------- */
footer{background:var(--navy-deep);color:#9aa5c2;padding:70px 0 30px;position:relative}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--red) 0 34%,#fff 34% 50%,var(--navy-mid) 50% 100%)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px;margin-bottom:40px}
footer h4{color:#fff;text-transform:uppercase;letter-spacing:1.5px;font-size:.95rem;margin-bottom:18px;font-family:"Oswald",sans-serif}
footer a{color:#9aa5c2;display:block;margin-bottom:10px;font-size:.94rem;transition:color .2s,padding-left .2s}
footer a:hover{color:#fff;padding-left:5px}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.foot-logo-plate{display:inline-block;background:#fff;padding:14px 18px;border-radius:8px;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.foot-logo-plate img{height:52px;width:auto;display:block}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;color:var(--steel)}
.foot-bottom a{display:inline;color:var(--steel)}
.foot-bottom a:hover{color:#fff}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .split{grid-template-columns:1fr;gap:36px}
  .split.rev .split-media{order:0}
  .split-media{min-height:300px}
}
@media (max-width:820px){
  .navlinks{display:none;position:absolute;top:92px;left:0;right:0;background:#fff;flex-direction:column;padding:22px 28px;gap:20px;border-bottom:1px solid var(--line);box-shadow:0 12px 24px rgba(5,16,46,.1)}
  .navlinks.open{display:flex}
  .menu-btn{display:block}
  .grid-3,.grid-2,.contact-grid,.foot-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:40px 20px}
  .stat:not(:last-child)::after{display:none}
  .stat:nth-child(odd)::after{content:"";display:block;position:absolute;right:-10px;top:15%;height:70%;width:1px;background:rgba(255,255,255,.14)}
  .section{padding:64px 0}
  .hero{min-height:auto;padding:90px 0}
  .form-card{padding:28px}
  .hero-tag{display:none}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto}
}
