/* ==========================================================================
   TM Trailer Rentals — heavy-duty equipment aesthetic
   Display: Saira Condensed (technical/industrial)  ·  Body: Inter
   Data/tags: JetBrains Mono  ·  Single accent: brand orange on steel
   ========================================================================== */

:root{
  --bg:#111417;
  --bg-2:#0c0e10;
  --surface:#181d22;
  --surface-2:#1f242b;
  --surface-3:#272d35;
  --line:rgba(233,238,243,.10);
  --line-2:rgba(233,238,243,.16);

  --ink:#eef1f4;
  --ink-2:#c6cdd5;
  --muted:#8d97a1;

  --brand:#f26a21;
  --brand-bri:#ff8c42;
  --brand-deep:#c2531a;
  --brand-ink:#2a1306;
  --steel:#b8c1cb;
  --warn:#f6a93c;

  --r:14px; --r-sm:9px; --r-lg:20px; --r-pill:999px;
  --shadow-sm:0 2px 10px rgba(0,0,0,.30);
  --shadow:0 16px 38px rgba(0,0,0,.42);
  --shadow-lg:0 30px 64px rgba(0,0,0,.50);

  --ff-display:"Saira Condensed",Impact,"Arial Narrow",system-ui,sans-serif;
  --ff-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;

  --maxw:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

a{color:var(--brand-bri);text-decoration:none}
a:hover{color:var(--brand)}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

::selection{background:var(--brand);color:#fff}

:focus-visible{outline:3px solid var(--brand-bri);outline-offset:3px;border-radius:6px}

.skip-link{
  position:absolute;left:14px;top:-60px;z-index:200;
  background:var(--brand);color:#fff;font-weight:600;
  padding:10px 16px;border-radius:0 0 10px 10px;transition:top .18s ease;
  font-family:var(--ff-body)
}
.skip-link:focus{top:0;color:#fff}

/* steel tread-plate texture used sparingly as a signature surface accent */
.tread{
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,.045) 0 2px, transparent 2px 9px),
    repeating-linear-gradient(-45deg, rgba(0,0,0,.16) 0 2px, transparent 2px 9px);
}

/* ============================ HEADER ============================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(12,14,16,.78);
  backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(255,255,255,.03);
}
.site-header::before{ /* hazard hairline — the one industrial flourish */
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:repeating-linear-gradient(135deg,var(--brand) 0 14px,#13161a 14px 28px);
  opacity:.9;
}
.header-inner{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  gap:16px;padding:13px 0;position:relative;
  transition:padding .25s ease;
}
.header-logo{display:flex;align-items:center}
.header-logo img{height:66px;width:auto;transition:height .25s ease}
.site-header.shrink .header-inner{padding:7px 0}
.site-header.shrink .header-logo img{height:48px}

.header-title{justify-self:start}
.brand-text{
  font-family:var(--ff-display);
  font-weight:700;font-size:1.45rem;letter-spacing:.04em;
  color:var(--ink);text-transform:uppercase;line-height:1;
  display:inline-block;
}
.brand-text::after{
  content:"";display:block;height:2px;width:42px;background:var(--brand);
  margin-top:4px;border-radius:2px;
}

/* nav — inline on desktop */
.nav-toggle{
  display:none;border:1px solid var(--line-2);background:var(--surface-2);
  cursor:pointer;padding:11px;border-radius:10px;flex-direction:column;gap:4px;
  justify-self:end;
}
.nav-toggle span{display:block;width:22px;height:2px;border-radius:999px;background:var(--ink)}
.primary-nav{justify-self:end}
.primary-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:6px}
.primary-nav li a{
  display:block;padding:9px 16px;border-radius:var(--r-pill);
  color:var(--ink-2);font-weight:600;font-size:.95rem;letter-spacing:.02em;
  position:relative;transition:color .15s ease,background .15s ease;
}
.primary-nav li a:hover{color:var(--ink);background:var(--surface-2)}
.primary-nav li a::after{
  content:"";position:absolute;left:16px;right:16px;bottom:5px;height:2px;
  background:var(--brand);transform:scaleX(0);transform-origin:left;
  transition:transform .2s ease;border-radius:2px;
}
.primary-nav li a:hover::after{transform:scaleX(1)}

@media (max-width:760px){
  .nav-toggle{display:flex}
  .primary-nav{
    position:absolute;right:22px;top:100%;margin-top:10px;min-width:180px;
    background:var(--surface);border:1px solid var(--line-2);border-radius:14px;
    box-shadow:var(--shadow);padding:8px;display:none;
  }
  .primary-nav.nav-open{display:block;animation:drop .18s ease}
  .primary-nav ul{flex-direction:column;gap:2px}
  .primary-nav li a{border-radius:9px}
  .primary-nav li a::after{display:none}
}
@keyframes drop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ============================ HERO ============================ */
.hero{position:relative;isolation:isolate;overflow:hidden;
  min-height:clamp(480px,78vh,720px);display:flex;align-items:flex-end}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img{
  width:100%;height:100%;object-fit:cover;object-position:50% 42%;
  animation:heroZoom 22s ease-out forwards;
}
@media (prefers-reduced-motion:reduce){.hero-media img{animation:none}}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-scrim{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(12,14,16,.30) 0%,rgba(12,14,16,.10) 28%,rgba(12,14,16,.62) 66%,var(--bg) 100%),
    linear-gradient(90deg,rgba(12,14,16,.78) 0%,rgba(12,14,16,.30) 52%,rgba(12,14,16,.04) 100%);
}
.hero-inner{padding:0 22px 56px;width:100%}
.hero-content{max-width:760px;animation:rise .7s cubic-bezier(.2,.7,.2,1) both}
@media (prefers-reduced-motion:reduce){.hero-content{animation:none}}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

.hero-title{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(2.3rem,5.4vw,4rem);line-height:.98;letter-spacing:.005em;
  margin:0 0 18px;color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.55);
  text-wrap:balance;
}
.hero-sub{
  font-size:clamp(1rem,1.7vw,1.22rem);font-weight:500;color:var(--ink);
  margin:0 0 22px;text-shadow:0 1px 12px rgba(0,0,0,.6);max-width:620px;
}
.hero-benefits{
  list-style:none;margin:0 0 28px;padding:0;
  display:flex;flex-wrap:wrap;gap:9px;
}
.hero-benefits li{
  font-size:.86rem;font-weight:600;letter-spacing:.02em;color:var(--ink);
  background:rgba(24,29,34,.72);border:1px solid var(--line-2);
  backdrop-filter:blur(6px);
  padding:7px 13px 7px 28px;border-radius:var(--r-pill);position:relative;
}
.hero-benefits li::before{
  content:"";position:absolute;left:11px;top:50%;transform:translateY(-50%);
  width:9px;height:9px;border-radius:50%;
  background:var(--brand);box-shadow:0 0 0 3px rgba(242,106,33,.22);
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

.phone-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-display);font-weight:700;font-size:1.5rem;letter-spacing:.03em;
  color:#fff;background:linear-gradient(180deg,var(--brand-bri),var(--brand-deep));
  padding:13px 26px;border-radius:13px;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 10px 26px rgba(242,106,33,.42),inset 0 1px 0 rgba(255,255,255,.35);
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease;
  white-space:nowrap;
}
.phone-cta:hover{transform:translateY(-2px);color:#fff;filter:brightness(1.04);
  box-shadow:0 16px 34px rgba(242,106,33,.5),inset 0 1px 0 rgba(255,255,255,.4)}
.phone-cta:active{transform:translateY(0)}

/* ============================ TRUST PANEL ============================ */
.trust{padding:34px 0 6px;background:var(--bg)}
.trust-panel{
  background:linear-gradient(180deg,var(--surface-2),var(--surface));
  border:1px solid var(--line-2);border-left:4px solid var(--brand);
  border-radius:var(--r);padding:26px 30px;box-shadow:var(--shadow-sm);
  max-width:980px;
}
.storybox p{margin:.55em 0;color:var(--ink-2);font-size:1.04rem;line-height:1.6}
.storybox p:first-child{margin-top:0}
.storybox p:last-child{margin-bottom:0}
.storybox strong{color:var(--ink);font-weight:700;font-size:1.12rem}
.storybox .em{
  color:var(--brand-bri);font-weight:600;
  background:rgba(242,106,33,.10);padding:1px 6px;border-radius:6px;
}

/* ============================ SECTIONS ============================ */
.section{padding:64px 0}
.section + .section{border-top:1px solid var(--line)}
.section-head{margin-bottom:30px}
.section-head h2{
  font-family:var(--ff-display);font-weight:800;
  font-size:clamp(2rem,4vw,2.9rem);letter-spacing:.03em;
  text-transform:uppercase;color:#fff;margin:0;line-height:1;
  display:inline-block;position:relative;padding-bottom:12px;
}
.section-head h2::after{
  content:"";position:absolute;left:0;bottom:0;height:4px;width:72px;
  background:linear-gradient(90deg,var(--brand),transparent);border-radius:3px;
}
.lead{color:var(--muted);font-size:1.06rem;margin:.7rem 0 0;max-width:60ch}

/* ============================ FLEET ============================ */
.fleet-grid{
  display:grid;gap:22px;margin-top:8px;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
}
.trailer-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;
  box-shadow:var(--shadow-sm);
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
}
.trailer-card:hover{
  transform:translateY(-5px);border-color:var(--line-2);box-shadow:var(--shadow)
}
.trailer-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a0c0e}
.trailer-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.trailer-card:hover .trailer-media img{transform:scale(1.06)}
.trailer-media::after{ /* gentle bottom fade so the title sits cleanly */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 62%,rgba(10,12,14,.55) 100%);
}

/* signature: stamped metal rental price tag */
.price-tag{
  position:absolute;top:12px;right:12px;z-index:2;
  display:flex;align-items:center;
  background:linear-gradient(180deg,var(--brand-bri),var(--brand-deep));
  color:var(--brand-ink);
  border:1px solid rgba(255,255,255,.3);
  border-radius:8px;padding:6px 12px 6px 22px;
  box-shadow:0 8px 18px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.45);
  transform:rotate(-3deg);transform-origin:top right;
  transition:transform .2s ease;
}
.trailer-card:hover .price-tag{transform:rotate(0deg)}
.price-tag::before{ /* punched hole of a hang tag */
  content:"";position:absolute;left:9px;top:50%;transform:translateY(-50%);
  width:7px;height:7px;border-radius:50%;
  background:#0c0e10;box-shadow:inset 0 1px 1px rgba(0,0,0,.8);
}
.price-tag-amt{
  font-family:var(--ff-mono);font-weight:700;font-size:.92rem;letter-spacing:-.01em;
  white-space:nowrap;text-shadow:0 1px 0 rgba(255,255,255,.18);
}

.trailer-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.trailer-body h3{
  font-family:var(--ff-display);font-weight:700;font-size:1.5rem;letter-spacing:.02em;
  margin:0 0 6px;color:#fff;line-height:1.05;
}
.trailer-desc{color:var(--ink-2);font-size:.97rem;margin:0 0 16px;flex:1}

.more-info-toggle{
  align-self:flex-start;
  font-family:var(--ff-body);font-weight:600;font-size:.9rem;letter-spacing:.02em;
  color:var(--brand-bri);background:rgba(242,106,33,.08);
  border:1px solid rgba(242,106,33,.35);border-radius:var(--r-pill);
  padding:9px 18px;cursor:pointer;
  transition:background .15s ease,color .15s ease,border-color .15s ease;
}
.more-info-toggle:hover{background:rgba(242,106,33,.16);color:#fff;border-color:var(--brand)}
.more-info-toggle[aria-expanded="true"]{background:var(--brand);color:#fff;border-color:var(--brand)}

/* smooth height expand via grid-rows */
.more-info-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}
.more-info-wrap.open{grid-template-rows:1fr}
.more-info{overflow:hidden;min-height:0}
.more-info:not([hidden]){margin-top:16px}

/* spec sheet content */
.more-info p{margin:.5em 0;color:var(--ink-2);font-size:.93rem;line-height:1.55}
.more-info p:first-child{margin-top:0}
.spec-head{
  font-family:var(--ff-display);font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--steel);font-size:1rem !important;
  border-bottom:1px solid var(--line);padding-bottom:6px;margin:.2em 0 .5em !important;
}
.spec-list{list-style:none;margin:.4em 0;padding:0;display:grid;gap:6px}
.spec-list li{
  position:relative;padding-left:20px;color:var(--ink-2);
  font-size:.92rem;line-height:1.5;
}
.spec-list li::before{
  content:"";position:absolute;left:3px;top:.62em;
  width:6px;height:6px;border-radius:1.5px;background:var(--brand);
  transform:rotate(45deg);
}
.spec-list li.spec-warn{
  color:var(--warn);font-weight:600;letter-spacing:.01em;
}
.spec-list li.spec-warn::before{background:var(--warn);border-radius:50%;transform:none}
.spec-price{
  font-family:var(--ff-mono);font-weight:700;color:var(--brand-bri);
  background:rgba(242,106,33,.10);padding:1px 6px;border-radius:5px;
}
.spec-note{color:var(--muted) !important;font-size:.85rem !important;font-style:italic}

.fleet-footnote{
  margin:30px 0 0;padding:18px 22px;border-radius:var(--r);
  border:1px solid var(--line-2);border-left:5px solid var(--brand);
  background:var(--surface-2);color:var(--ink);
  font-family:var(--ff-display);font-weight:600;font-size:1.18rem;letter-spacing:.02em;
  text-align:center;
}
.fleet-footnote strong{color:#fff;font-weight:700}

/* ============================ GALLERY ============================ */
.gallery-grid{
  display:grid;gap:14px;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
}
.g-item{margin:0}
.g-item a{
  display:block;position:relative;aspect-ratio:4/3;overflow:hidden;
  border-radius:var(--r);border:1px solid var(--line);background:#0a0c0e;
}
.g-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .45s ease,filter .45s ease;
}
.g-item a::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(10,12,14,.4));
  opacity:0;transition:opacity .3s ease;
}
.g-item a:hover img{transform:scale(1.07)}
.g-item a:hover::after{opacity:1}
.g-item a:focus-visible{outline-offset:0}

/* CSS-only lightbox via :target */
.lightbox{
  position:fixed;inset:0;z-index:1000;display:none;
  align-items:center;justify-content:center;padding:24px;
  background:rgba(8,10,12,.92);backdrop-filter:blur(6px);
}
.lightbox:target{display:flex;animation:lbin .2s ease}
@keyframes lbin{from{opacity:0}to{opacity:1}}
.lightbox img{
  max-width:94vw;max-height:88vh;border-radius:14px;
  box-shadow:0 30px 80px rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.1);
}
.lightbox .close{
  position:absolute;top:20px;right:24px;
  font-family:var(--ff-body);font-weight:600;color:#fff;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  padding:9px 15px;border-radius:10px;backdrop-filter:blur(4px);
  transition:background .15s ease;
}
.lightbox .close:hover{background:rgba(255,255,255,.2);color:#fff}

/* ============================ CONTACT ============================ */
.contact-section{background:var(--bg)}
.contact-card{
  background:linear-gradient(180deg,var(--surface-2),var(--surface));
  border:1px solid var(--line-2);border-radius:var(--r-lg);
  padding:30px 34px;box-shadow:var(--shadow-sm);max-width:740px;
}
.contact-card p{
  margin:0;padding:14px 0;border-bottom:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:6px 14px;align-items:baseline;
  font-size:1.02rem;color:var(--ink-2);
}
.contact-card p:last-child{border-bottom:0;padding-bottom:0}
.contact-card p strong{
  color:var(--steel);font-weight:600;min-width:96px;
  font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;
}
.contact-card a{color:var(--brand-bri);font-weight:600;word-break:break-word}
.contact-card a:hover{color:var(--brand)}
.contact-card p.lead{
  border:0;color:var(--muted);font-size:.95rem;padding-top:16px;
  display:block;
}
/* phone gets emphasis — it is the primary action */
.contact-card p:first-of-type{padding-top:0}
.contact-card p:first-of-type a{
  font-family:var(--ff-display);font-weight:700;font-size:1.5rem;letter-spacing:.03em;
  color:#fff;
}
.contact-card p:first-of-type a:hover{color:var(--brand-bri)}

/* ============================ FOOTER ============================ */
footer{
  padding:30px 0;text-align:center;color:var(--muted);
  background:var(--bg-2);border-top:1px solid var(--line);font-size:.92rem;
  position:relative;
}
footer::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;
  background:repeating-linear-gradient(135deg,var(--brand) 0 14px,transparent 14px 28px);
  opacity:.55;
}

/* ============================ REVEAL ============================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.fleet-grid .reveal{transition-delay:calc(var(--i,0) * 60ms)}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none}
  *{animation-duration:.001ms !important}
}

/* ============================ RESPONSIVE ============================ */
@media (max-width:900px){
  .section{padding:52px 0}
}
@media (max-width:620px){
  .container{padding:0 16px}
  .header-logo img{height:54px}
  .site-header.shrink .header-logo img{height:42px}
  .brand-text{font-size:1.15rem}
  .hero{min-height:clamp(440px,72vh,560px)}
  .hero-inner{padding-bottom:40px}
  .trust-panel{padding:22px 20px}
  .fleet-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;gap:10px}
  .contact-card{padding:24px 20px}
  .contact-card p{flex-direction:column;gap:2px}
  .contact-card p strong{min-width:0}
  .phone-cta{font-size:1.3rem;padding:12px 20px}
}
@media (max-width:380px){
  .gallery-grid{grid-template-columns:1fr}
}
