/* ===================================================================
   FORM GUY SUPPLY — style.css
   Palette grounded in the formwork material world:
   concrete charcoal · safety amber · oxide-steel red · blueprint blue
   =================================================================== */

:root{
  --concrete:    #13161a;   /* base */
  --concrete-2:  #181c21;   /* section alt */
  --surface:     #1d2228;   /* raised cards */
  --surface-2:   #242a31;   /* hover */
  --line:        #2c333b;   /* hairlines */
  --line-2:      #39424c;

  --amber:       #f4a721;   /* safety / formply */
  --amber-deep:  #d6860f;
  --steel:       #c1543a;   /* oxide waler red */
  --blueprint:   #5b91e8;   /* logo nod / links */

  --bone:        #ece6da;   /* primary text */
  --bone-dim:    #b8bdc4;
  --mute:        #8a929c;   /* muted */
  --mute-2:      #5f6973;

  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);

  --f-display: "Saira Condensed", "Arial Narrow", sans-serif;
  --f-body: "Inter", system-ui, sans-serif;
  --f-mono: "IBM Plex Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--concrete);
  color:var(--bone);
  font-family:var(--f-body);
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

::selection{ background:var(--amber); color:#1a1205; }

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--amber);
  display:inline-flex;
  align-items:center;
  gap:.65em;
  margin:0 0 1.1rem;
}
.eyebrow--light{ color:var(--amber); }
.tick{
  width:26px; height:2px; background:var(--amber); display:inline-block;
  position:relative; flex:none;
}
.tick::before,.tick::after{
  content:""; position:absolute; top:-3px; width:2px; height:8px; background:var(--amber);
}
.tick::before{ left:0; } .tick::after{ right:0; }

.section__title{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(2rem,4.6vw,3.4rem);
  line-height:.98;
  letter-spacing:.005em;
  text-transform:uppercase;
  margin:0 0 1rem;
  color:var(--bone);
}
.amber{ color:var(--amber); }

/* ---------- dimension line (signature) ---------- */
.dimline{
  display:flex; align-items:center; gap:.85rem; width:100%;
  margin:1.6rem 0;
}
.dimline__rule{ flex:1; height:1px; background:var(--line-2); }
.dimline__tick{
  width:1px; height:13px; background:var(--amber); flex:none;
}
.dimline__label{
  font-family:var(--f-mono);
  font-size:.66rem;
  letter-spacing:.2em;
  color:var(--mute);
  white-space:nowrap;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--f-display);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:1.02rem;
  padding:.92em 1.5em;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  will-change:transform;
}
.btn--amber{ background:var(--amber); color:#1a1205; }
.btn--amber:hover{ background:#ffbb3d; transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--bone); border-color:var(--line-2); }
.btn--ghost:hover{ border-color:var(--amber); color:var(--amber); transform:translateY(-2px); }
.btn--full{ width:100%; }

/* ===================================================================
   HEADER
   =================================================================== */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:padding .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  padding:11px var(--gutter);
  background:rgba(16,19,23,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__mark{ width:40px; height:40px; transition:width .3s var(--ease), height .3s var(--ease); }
.scrolled .brand__mark{ width:34px; height:34px; }
.brand__words{ display:flex; flex-direction:column; line-height:.86; font-family:var(--f-display); text-transform:uppercase; }
.brand__line1{ font-weight:800; font-size:1.18rem; letter-spacing:.02em; color:var(--bone); }
.brand__line2{ font-weight:700; font-size:1.18rem; letter-spacing:.34em; color:var(--blueprint); }

.nav{ display:flex; align-items:center; gap:clamp(1rem,2vw,2rem); }
.nav a{
  font-family:var(--f-mono); font-size:.78rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--bone-dim); position:relative; padding:.3em 0;
  transition:color .2s var(--ease);
}
.nav a:not(.nav__cta)::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--amber);
  transition:width .28s var(--ease);
}
.nav a:not(.nav__cta):hover{ color:var(--bone); }
.nav a:not(.nav__cta):hover::after{ width:100%; }
.nav__cta{
  color:var(--amber); border:1px solid var(--amber); padding:.55em 1.1em;
  transition:background .22s var(--ease), color .22s var(--ease);
}
.nav__cta:hover{ background:var(--amber); color:#1a1205; }

.menu-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px;
}
.menu-toggle span{ width:26px; height:2px; background:var(--bone); transition:transform .3s var(--ease), opacity .3s var(--ease); }
.menu-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0; z-index:45;
  background:rgba(14,17,20,.97); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.4rem;
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease);
}
.mobile-menu.open{ opacity:1; pointer-events:auto; }
.mobile-menu a{
  font-family:var(--f-display); text-transform:uppercase; font-size:1.8rem; font-weight:700;
  letter-spacing:.04em; color:var(--bone);
}
.mobile-menu a:hover{ color:var(--amber); }
.mobile-menu__cta{ color:var(--amber)!important; }

/* ===================================================================
   HERO
   =================================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{
  width:100%; height:100%; object-fit:cover; object-position:center 58%;
  transform:scale(1.08); animation:heroZoom 18s ease-out forwards;
}
@keyframes heroZoom{ to{ transform:scale(1); } }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,18,22,.72) 0%, rgba(15,18,22,.30) 38%, rgba(15,18,22,.55) 72%, var(--concrete) 100%),
    linear-gradient(90deg, rgba(15,18,22,.85) 0%, rgba(15,18,22,.15) 55%, rgba(15,18,22,0) 100%);
}
.hero__grid{
  position:absolute; inset:0; opacity:.16; mix-blend-mode:overlay;
  background-image:
    linear-gradient(var(--bone) 1px, transparent 1px),
    linear-gradient(90deg, var(--bone) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 30%, #000 60%, transparent);
          mask-image:linear-gradient(180deg, transparent, #000 30%, #000 60%, transparent);
}
.hero__inner{
  position:relative; z-index:2;
  max-width:var(--maxw); width:100%;
  margin:0 auto; padding:clamp(96px,14vh,160px) var(--gutter) 0;
}
.hero__title{
  font-family:var(--f-display); font-weight:900; text-transform:uppercase;
  font-size:clamp(2.9rem,8.4vw,7rem); line-height:.92; letter-spacing:.005em;
  margin:.2em 0 0; color:var(--bone);
  text-shadow:0 4px 40px rgba(0,0,0,.35);
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line > span{ display:block; transform:translateY(110%); }
.hero__lede{
  max-width:46ch; color:var(--bone-dim); font-size:clamp(1rem,1.4vw,1.18rem);
  margin:0 0 2rem;
}
.hero__actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.hero__dim{ max-width:520px; }
.hero__dim .dimline__label{ color:var(--bone-dim); }

.hero__scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:3;
  width:26px; height:42px; border:1px solid var(--line-2); border-radius:14px;
  display:flex; justify-content:center; padding-top:7px;
}
.hero__scroll span{ width:3px; height:8px; background:var(--amber); border-radius:2px; animation:scrollDot 1.8s var(--ease) infinite; }
@keyframes scrollDot{ 0%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(14px); opacity:0; } 100%{ opacity:0; } }

/* ===================================================================
   STATS
   =================================================================== */
.stats{
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--concrete-2);
}
.stat{
  padding:clamp(1.6rem,3vw,2.6rem) var(--gutter);
  border-right:1px solid var(--line);
  display:flex; flex-direction:column; gap:.35rem;
}
.stat:last-child{ border-right:0; }
.stat__num{
  font-family:var(--f-display); font-weight:800; font-size:clamp(2.4rem,4.5vw,3.6rem);
  line-height:1; color:var(--amber); letter-spacing:.01em;
}
.stat__num--text{ color:var(--bone); }
.stat__label{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mute); }

/* ===================================================================
   SECTION SCAFFOLD
   =================================================================== */
.section{ max-width:var(--maxw); margin:0 auto; padding:clamp(4.5rem,9vw,8rem) var(--gutter); }
.section__head{ max-width:760px; margin-bottom:clamp(2.4rem,4vw,3.6rem); }
.section__sub{ color:var(--mute); max-width:60ch; margin:.4rem 0 0; }

/* ===================================================================
   SYSTEMS
   =================================================================== */
.systems__grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem;
}
.syscard{
  grid-column:span 1;
  background:var(--surface); border:1px solid var(--line);
  display:flex; flex-direction:column; overflow:hidden;
  transition:border-color .3s var(--ease), transform .3s var(--ease);
}
.syscard--wide{ grid-column:span 2; flex-direction:row; }
.syscard:hover{ border-color:var(--line-2); transform:translateY(-3px); }
.syscard__media{ overflow:hidden; position:relative; }
.syscard--wide .syscard__media{ flex:1 1 46%; min-height:280px; }
.syscard:not(.syscard--wide) .syscard__media{ aspect-ratio:16/10; }
.syscard__media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .7s var(--ease); filter:saturate(1.02);
}
.syscard:hover .syscard__media img{ transform:scale(1.06); }
.syscard__media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 55%, rgba(19,22,26,.55));
  pointer-events:none;
}
.syscard__body{ padding:clamp(1.4rem,2.4vw,2rem); display:flex; flex-direction:column; gap:.55rem; flex:1; }
.syscard--wide .syscard__body{ justify-content:center; flex:1 1 54%; }
.syscard__index{
  font-family:var(--f-mono); font-size:.74rem; letter-spacing:.18em; color:var(--steel); font-weight:600;
}
.syscard__body h3{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(1.4rem,2.4vw,2rem); line-height:1; margin:0; letter-spacing:.01em;
}
.syscard__body p{ color:var(--bone-dim); margin:.2rem 0 .4rem; font-size:.96rem; }
.taglist{ list-style:none; padding:0; margin:auto 0 0; display:flex; flex-wrap:wrap; gap:.4rem; }
.taglist li{
  font-family:var(--f-mono); font-size:.68rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--mute); border:1px solid var(--line); padding:.35em .7em;
}
.systems__note{
  margin-top:2.4rem; font-family:var(--f-mono); font-size:.82rem; letter-spacing:.04em;
  color:var(--mute); display:flex; gap:.8rem; flex-wrap:wrap; align-items:center;
}
.systems__note a{ color:var(--amber); }
.systems__note a:hover{ text-decoration:underline; }

/* ===================================================================
   CAPABILITIES
   =================================================================== */
.capabilities{
  display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(2rem,5vw,5rem); align-items:center;
}
.cap__media{ position:relative; }
.cap__media img{ width:100%; aspect-ratio:4/3.4; object-fit:cover; border:1px solid var(--line); }
.cap__dim{ margin:1rem 0 0; }
.cap__lede{ color:var(--bone-dim); font-size:1.08rem; max-width:48ch; margin:0 0 1.8rem; }
.cap__rows{ display:flex; flex-direction:column; border-top:1px solid var(--line); }
.cap__row{
  display:grid; grid-template-columns:minmax(120px,180px) 1fr; gap:1rem;
  padding:1rem 0; border-bottom:1px solid var(--line); align-items:baseline;
}
.cap__row-k{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:1.18rem; letter-spacing:.02em; color:var(--amber);
}
.cap__row-v{ color:var(--bone-dim); font-size:.96rem; }

/* ===================================================================
   PROJECTS / GALLERY
   =================================================================== */
.projects{ }
.gallery{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:1rem; grid-auto-flow:dense;
}
.gallery__item{
  position:relative; overflow:hidden; margin:0; cursor:pointer;
  border:1px solid var(--line); background:var(--surface);
}
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--wide{ grid-column:span 2; }
.gallery__item img{
  width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease), filter .4s var(--ease);
  filter:saturate(.96) brightness(.94);
}
.gallery__item:hover img{ transform:scale(1.07); filter:saturate(1.05) brightness(1); }
.gallery__item figcaption{
  position:absolute; left:0; right:0; bottom:0;
  font-family:var(--f-mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--bone); padding:.7rem .8rem;
  background:linear-gradient(transparent, rgba(12,15,18,.9));
  transform:translateY(8px); opacity:0; transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.gallery__item:hover figcaption{ transform:translateY(0); opacity:1; }
.gallery__item::before{
  content:""; position:absolute; top:0; left:0; width:0; height:3px; background:var(--amber); z-index:2;
  transition:width .4s var(--ease);
}
.gallery__item:hover::before{ width:100%; }

/* ===================================================================
   REVIEWS
   =================================================================== */
.reviews{ }
.reviews__head{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center;
  margin-bottom:clamp(2rem,4vw,3rem); padding-bottom:2rem; border-bottom:1px solid var(--line);
}
.reviews__score{ display:flex; flex-direction:column; gap:.2rem; }
.reviews__big{ font-family:var(--f-display); font-weight:900; font-size:clamp(3.4rem,7vw,5.2rem); line-height:.85; color:var(--bone); }
.reviews__stars{ color:var(--amber); font-size:1.3rem; letter-spacing:.15em; }
.reviews__count{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mute); }
.reviews__lede{ font-size:clamp(1.15rem,2vw,1.5rem); font-family:var(--f-display); font-weight:500; line-height:1.25; color:var(--bone-dim); max-width:30ch; }
.reviews__grid{ columns:3; column-gap:1.25rem; }
.reviews__grid blockquote{
  break-inside:avoid; margin:0 0 1.25rem; padding:1.4rem 1.5rem;
  background:var(--surface); border:1px solid var(--line); border-left:2px solid var(--amber);
}
.quote-stars{ color:var(--amber); font-size:.9rem; letter-spacing:.12em; }
.reviews__grid blockquote p{ margin:.6rem 0 1rem; color:var(--bone); font-size:1rem; }
.reviews__grid cite{ font-style:normal; font-family:var(--f-mono); font-size:.74rem; letter-spacing:.06em; color:var(--bone-dim); }
.reviews__grid cite span{ color:var(--mute); }

/* ===================================================================
   STORY
   =================================================================== */
.story{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.story__media img{ width:100%; aspect-ratio:5/4; object-fit:cover; border:1px solid var(--line); }
.story__text p{ color:var(--bone-dim); margin:0 0 1.1rem; }
.story__dim{ margin-top:1.8rem; }

/* ===================================================================
   DOWNLOADS
   =================================================================== */
.dl__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.dl__card{
  background:var(--surface); border:1px solid var(--line); padding:1.6rem 1.5rem 1.4rem;
  display:flex; flex-direction:column; gap:.55rem; min-height:200px;
  transition:border-color .3s var(--ease), transform .3s var(--ease), background .3s var(--ease);
}
.dl__card:hover{ border-color:var(--amber); transform:translateY(-3px); background:var(--surface-2); }
.dl__index{ font-family:var(--f-mono); font-size:.68rem; letter-spacing:.18em; color:var(--steel); }
.dl__card h3{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:1.35rem; margin:0; letter-spacing:.01em; }
.dl__card p{ color:var(--mute); font-size:.9rem; margin:0; }
.dl__go{ margin-top:auto; font-family:var(--f-mono); font-size:.78rem; letter-spacing:.08em; color:var(--amber); }

/* ===================================================================
   CONTACT
   =================================================================== */
.contact__grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.contact__lede{ color:var(--bone-dim); margin:0 0 1.8rem; font-size:1.08rem; }
.contact__list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; }
.contact__list li{
  display:grid; grid-template-columns:88px 1fr; gap:1rem; padding:.9rem 0;
  border-top:1px solid var(--line); align-items:baseline;
}
.contact__list li:last-child{ border-bottom:1px solid var(--line); }
.contact__k{ font-family:var(--f-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); }
.contact__list a:hover{ color:var(--amber); }

.contact__form{ background:var(--surface); border:1px solid var(--line); padding:clamp(1.6rem,3vw,2.4rem); }
.form__eyebrow{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--amber); margin:0 0 1.4rem; }
.field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ font-family:var(--f-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--mute); }
.field input,.field select,.field textarea{
  font-family:var(--f-body); font-size:.96rem; color:var(--bone);
  background:var(--concrete); border:1px solid var(--line-2); padding:.8em .9em;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
  width:100%; border-radius:0;
}
.field textarea{ resize:vertical; }
.field input::placeholder,.field textarea::placeholder{ color:var(--mute-2); }
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none; border-color:var(--amber); box-shadow:0 0 0 3px rgba(244,167,33,.16);
}
.field select{ appearance:none; cursor:pointer; }
.field.invalid input,.field.invalid select{ border-color:var(--steel); }
.form__note{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.04em; color:var(--mute); margin:.9rem 0 0; }
.form__note.ok{ color:var(--amber); }
.form__note.err{ color:var(--steel); }

.map{ margin-top:clamp(2.5rem,5vw,4rem); border:1px solid var(--line); overflow:hidden; }
.map iframe{ width:100%; height:420px; border:0; display:block; filter:grayscale(.35) contrast(1.05); }

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{ border-top:1px solid var(--line); background:var(--concrete-2); }
.footer__top{
  max-width:var(--maxw); margin:0 auto; padding:clamp(2.5rem,5vw,4rem) var(--gutter) 1.6rem;
  display:flex; justify-content:space-between; align-items:center; gap:2rem; flex-wrap:wrap;
}
.footer__nav{ display:flex; gap:1.4rem; flex-wrap:wrap; }
.footer__nav a{ font-family:var(--f-mono); font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; color:var(--bone-dim); }
.footer__nav a:hover{ color:var(--amber); }
.footer__bottom{
  max-width:var(--maxw); margin:0 auto; padding:1.4rem var(--gutter) 2.4rem;
  border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
}
.footer__bottom p{ margin:0; font-family:var(--f-mono); font-size:.72rem; letter-spacing:.04em; color:var(--mute); }

/* ===================================================================
   LIGHTBOX
   =================================================================== */
.lightbox{
  position:fixed; inset:0; z-index:90; background:rgba(10,12,15,.94);
  display:flex; align-items:center; justify-content:center; padding:5vw;
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease);
}
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:100%; max-height:88vh; border:1px solid var(--line-2); box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lightbox__close{
  position:absolute; top:24px; right:30px; background:none; border:0; color:var(--bone);
  font-size:2.4rem; line-height:1; cursor:pointer; transition:color .2s var(--ease);
}
.lightbox__close:hover{ color:var(--amber); }

/* ===================================================================
   REVEAL ANIMATIONS
   =================================================================== */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
.hero__title .line.in > span{ transform:none; transition:transform .9s var(--ease); }

/* focus visibility */
a:focus-visible,.btn:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--amber); outline-offset:3px;
}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1024px){
  .nav{ display:none; }
  .menu-toggle{ display:flex; }
  .gallery{ grid-template-columns:repeat(3,1fr); }
  .reviews__grid{ columns:2; }
}
@media (max-width:760px){
  .stats{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2n){ border-right:0; }
  .stat:nth-child(-n+2){ border-bottom:1px solid var(--line); }
  .systems__grid{ grid-template-columns:1fr; }
  .syscard,.syscard--wide{ grid-column:span 1; }
  .syscard--wide{ flex-direction:column; }
  .syscard--wide .syscard__media{ min-height:0; aspect-ratio:16/10; }
  .capabilities{ grid-template-columns:1fr; }
  .story{ grid-template-columns:1fr; }
  .story__media{ order:-1; }
  .contact__grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gallery__item--wide{ grid-column:span 2; }
  .reviews__head{ grid-template-columns:1fr; }
  .reviews__grid{ columns:1; }
  .dl__grid{ grid-template-columns:1fr 1fr; }
  .footer__bottom{ flex-direction:column; }
}
@media (max-width:480px){
  .field-row{ grid-template-columns:1fr; }
  .dl__grid{ grid-template-columns:1fr; }
  .hero__actions .btn{ flex:1; }
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; }
  .hero__media img{ transform:none; }
  [data-reveal]{ opacity:1; transform:none; }
  .hero__title .line > span{ transform:none; }
}
