/* ============================================================
   E-K BAUUNTERNEHMEN — Enstrup & Kortmann
   Industrial / Bauakte Editorial  ·  2026 Redesign
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,400..900;1,400..900&family=Hanken+Grotesk:wght@300..800&family=Spline+Sans+Mono:wght@400;500;600&display=swap');

/* ---------- Design Tokens ---------- */
:root{
  --ink:        #0d0e10;   /* near-black base            */
  --ink-2:      #15171a;   /* raised dark panel          */
  --ink-3:      #1d2024;   /* card / border dark         */
  --concrete:   #f3efe8;   /* warm off-white             */
  --concrete-2: #e9e3d8;   /* deeper concrete            */
  --line:       #2a2d31;   /* hairline on dark           */
  --line-light: #d8d1c4;   /* hairline on light          */
  --red:        #e2001a;   /* signal red (brand)         */
  --red-deep:   #b80016;
  --red-glow:   rgba(226,0,26,.35);
  --fog:        #8b9096;   /* muted text on dark         */
  --slate:      #5b5f66;   /* muted text on light        */

  --font-display: 'Archivo', system-ui, sans-serif;
  --font-body:    'Hanken Grotesk', system-ui, sans-serif;
  --font-mono:    'Spline Sans Mono', ui-monospace, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --pad: clamp(1.25rem, 5vw, 7rem);
  --maxw: 1320px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--concrete);
  line-height:1.6;
  overflow-x:hidden;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
::selection{ background:var(--red); color:#fff; }

/* film grain + custom scrollbar */
body::after{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::-webkit-scrollbar{ width:10px; }
::-webkit-scrollbar-track{ background:var(--ink); }
::-webkit-scrollbar-thumb{ background:var(--ink-3); border-radius:0; }
::-webkit-scrollbar-thumb:hover{ background:var(--red); }

/* ---------- Typographic helpers ---------- */
.mono{
  font-family:var(--font-mono); font-weight:500;
  text-transform:uppercase; letter-spacing:.22em; font-size:.72rem;
}
.eyebrow{ display:inline-flex; align-items:center; gap:.7rem; color:var(--red); }
.eyebrow::before{ content:""; width:30px; height:1px; background:var(--red); }
.display{
  font-family:var(--font-display); font-weight:800; line-height:.95;
  letter-spacing:-.02em; text-transform:uppercase;
  font-stretch:expanded;
}

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
section{ position:relative; }
.section-pad{ padding-block:clamp(5rem, 11vh, 9rem); }
.bg-ink{ background:var(--ink); }
.bg-concrete{ background:var(--concrete); color:var(--ink); }

/* giant ghost index number behind sections */
.ghost-index{
  position:absolute; top:-.35em; right:var(--pad);
  font-family:var(--font-display); font-weight:900; font-stretch:expanded;
  font-size:clamp(7rem,22vw,20rem); line-height:1; letter-spacing:-.04em;
  pointer-events:none; user-select:none; z-index:0;
}
.bg-ink .ghost-index{ color:#fff; opacity:.03; }
.bg-concrete .ghost-index{ color:var(--ink); opacity:.045; }

/* ============================================================
   DEMO PASSWORT-GATE
   ============================================================ */
.gate{
  position:fixed; inset:0; z-index:100000;
  display:flex; align-items:center; justify-content:center; padding:var(--pad);
  background:var(--ink);
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:80px 80px;
}
.gate.hide{ opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s; }
.gate-card{
  width:100%; max-width:440px; background:var(--ink-2); border:1px solid var(--line);
  padding:clamp(1.8rem,4vw,2.8rem);
  clip-path:polygon(0 0,100% 0,100% 100%,18px 100%,0 calc(100% - 18px));
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.gate-tag{ display:inline-block; color:var(--red); border:1px solid var(--red); padding:.32rem .7rem; font-size:.62rem; }
.gate-title{
  font-family:var(--font-display); font-stretch:expanded; font-weight:800; text-transform:uppercase;
  font-size:clamp(1.6rem,4vw,2.2rem); margin-top:1.1rem; letter-spacing:-.01em; line-height:1.05;
}
.gate-text{ color:rgba(243,239,232,.78); margin-top:.9rem; font-size:.98rem; line-height:1.6; }
.gate-text b{ color:var(--concrete); }
.gate-form{ display:flex; gap:.7rem; margin-top:1.6rem; flex-wrap:wrap; }
.gate-input{
  flex:1 1 180px; background:var(--ink); border:1px solid var(--line); color:var(--concrete);
  padding:.95rem 1.1rem; font-family:var(--font-mono); font-size:.9rem; letter-spacing:.05em;
  outline:none; transition:border-color .3s;
}
.gate-input:focus{ border-color:var(--red); }
.gate-form .btn{ flex:0 0 auto; }
.gate-error{ color:var(--red); font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; margin-top:.9rem; }
.gate-foot{ color:var(--slate); font-size:.62rem; margin-top:1.8rem; }
body.gate-locked{ overflow:hidden; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--pad);
  transition:background .45s var(--ease), padding .45s var(--ease), border-color .45s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(13,14,16,.72);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
  padding-block:.7rem;
}
.brand{ display:flex; align-items:center; gap:.85rem; z-index:2; }
.brand img{ height:42px; width:auto; transition:height .45s var(--ease);
  /* logo art is black+red; lift it onto dark hero */
  filter:drop-shadow(0 0 0 transparent); }
.scrolled .brand img{ height:34px; }
.brand .brand-tag{ display:none; }

.site-header:not(.scrolled) .brand img{
  /* invert the black ink of the logo to read on the dark hero, keep red-ish */
  filter:brightness(0) invert(1);
}
.nav{ display:flex; align-items:center; gap:clamp(1.3rem,1.9vw,2.2rem); }
.nav a.navlink{
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.18em;
  text-transform:uppercase; color:rgba(243,239,232,.82); position:relative;
  padding-block:.4rem; transition:color .3s;
}
.nav a.navlink::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--red); transition:width .35s var(--ease);
}
.nav a.navlink:hover{ color:#fff; }
.nav a.navlink:hover::after{ width:100%; }

.cta-phone{
  display:inline-flex; align-items:center; gap:.6rem;
  background:var(--red); color:#fff; font-family:var(--font-mono);
  font-size:.76rem; letter-spacing:.12em; font-weight:600;
  padding:.78rem 1.25rem; white-space:nowrap; clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  transition:background .3s, transform .3s var(--ease);
}
.cta-phone:hover{ background:#fff; color:var(--ink); transform:translateY(-2px); }
.cta-phone svg{ width:15px; height:15px; }

/* burger */
.burger{ display:none; width:42px; height:42px; position:relative; z-index:1002; }
.burger span{ position:absolute; left:9px; right:9px; height:2px; background:#fff; transition:.35s var(--ease); }
.burger span:nth-child(1){ top:15px; }
.burger span:nth-child(2){ top:21px; }
.burger span:nth-child(3){ top:27px; }
body.menu-open .burger span:nth-child(1){ top:21px; transform:rotate(45deg); }
body.menu-open .burger span:nth-child(2){ opacity:0; }
body.menu-open .burger span:nth-child(3){ top:21px; transform:rotate(-45deg); }

/* mobile drawer */
.mobile-nav{
  position:fixed; inset:0; z-index:1001; background:var(--ink);
  display:flex; flex-direction:column; justify-content:center; gap:2.2rem;
  padding:clamp(6rem,14vh,8rem) var(--pad) clamp(2rem,5vh,3rem);
  overflow-y:auto; transform:translateY(-100%); transition:transform .6s var(--ease-out);
}
body.menu-open .mobile-nav{ transform:translateY(0); }
.mobile-links{ display:flex; flex-direction:column; }
.mobile-links a{
  font-family:var(--font-display); font-stretch:expanded; text-transform:uppercase;
  font-weight:800; font-size:clamp(1.9rem,8vw,3.2rem); letter-spacing:-.02em;
  line-height:1.1; color:var(--concrete); display:flex; align-items:baseline; gap:1rem;
  border-bottom:1px solid var(--line); padding-block:.9rem; transition:color .3s, padding-left .3s;
}
.mobile-links a .num{ font-family:var(--font-mono); font-size:.8rem; color:var(--red); font-weight:500; }
.mobile-links a:hover{ color:var(--red); padding-left:1rem; }
.mobile-cta{ display:flex; gap:.9rem; flex-wrap:wrap; }
.mobile-cta .btn{ flex:1 1 160px; justify-content:center; }
.mobile-cta .btn span{ justify-content:center; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:grid; grid-template-rows:1fr auto;
  overflow:hidden; isolation:isolate;
}
.hero-media{ position:absolute; inset:0; z-index:-2; }
.hero-media img{
  width:100%; height:100%; object-fit:cover; object-position:center 40%;
  transform:scale(1.12); animation:heroZoom 14s var(--ease-out) forwards;
}
@keyframes heroZoom{ to{ transform:scale(1); } }
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(13,14,16,.8) 0%, rgba(13,14,16,.4) 22%, rgba(13,14,16,.18) 40%, rgba(13,14,16,.68) 80%, var(--ink) 100%),
    linear-gradient(90deg, rgba(13,14,16,.82) 0%, rgba(13,14,16,.22) 58%, transparent 100%);
}
.hero-grid{
  position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.22;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:clamp(60px,9vw,120px) clamp(60px,9vw,120px);
  -webkit-mask-image:radial-gradient(circle at 25% 78%, #000, transparent 62%);
          mask-image:radial-gradient(circle at 25% 78%, #000, transparent 62%);
}
.hero-inner{ grid-row:2; align-self:end; width:100%; max-width:var(--maxw); margin-inline:auto;
  padding:clamp(8rem,18vh,11rem) var(--pad) clamp(3rem,9vh,6rem); }
.hero-top{
  position:absolute; top:clamp(6rem,14vh,9rem); left:0; right:0;
  display:flex; justify-content:space-between; padding-inline:var(--pad);
  text-shadow:0 1px 14px rgba(13,14,16,.7);
}
.hero-coord{ text-align:right; color:rgba(243,239,232,.72); line-height:1.8; }
.hero-coord b{ color:var(--concrete); font-weight:500; }

.hero-wordmark{
  font-family:var(--font-display); font-weight:900; font-stretch:expanded;
  text-transform:uppercase; letter-spacing:-.02em; line-height:.94;
  font-size:clamp(2.4rem, 7vw, 5.6rem); color:var(--concrete);
  max-width:16ch;
}
.hero-wordmark .amp{ color:var(--red); font-style:italic; font-weight:800; }
.hero h1{
  margin-top:clamp(1rem,2.4vh,1.8rem);
  font-family:var(--font-display); font-weight:700; font-stretch:expanded;
  letter-spacing:-.015em; line-height:1.06;
  font-size:clamp(1.4rem, 3vw, 2.4rem); max-width:22ch;
  color:rgba(243,239,232,.92);
}
.hero h1 .accent{ color:var(--red); }
.hero-sub{
  margin-top:1.4rem; max-width:46ch; color:rgba(243,239,232,.82);
  font-size:clamp(1rem,1.3vw,1.1rem); font-weight:300;
}
.hero-actions{ margin-top:2.4rem; display:flex; flex-wrap:wrap; gap:1rem 1.4rem; align-items:center; }
.btn{
  --bg:var(--red); --fg:#fff;
  display:inline-flex; align-items:center; gap:.7rem; background:var(--bg); color:var(--fg);
  font-family:var(--font-mono); font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; font-weight:600;
  padding:1.05rem 1.7rem; position:relative; overflow:hidden;
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
  transition:transform .35s var(--ease), color .35s;
}
.btn span{ position:relative; z-index:2; display:inline-flex; align-items:center; gap:.7rem; white-space:nowrap; }
.btn::before{
  content:""; position:absolute; inset:0; background:#fff; transform:translateY(101%);
  transition:transform .45s var(--ease); z-index:1;
}
.btn:hover{ color:var(--ink); transform:translateY(-3px); }
.btn:hover::before{ transform:translateY(0); }
.btn--ghost{ --bg:transparent; --fg:var(--concrete); box-shadow:inset 0 0 0 1px rgba(243,239,232,.4); }
.btn--ghost::before{ background:var(--red); }
.btn--ghost:hover{ color:#fff; box-shadow:inset 0 0 0 1px var(--red); }
.btn--dark{ --bg:var(--ink); --fg:#fff; }
.btn svg{ width:16px; height:16px; }

.scroll-cue{
  position:absolute; bottom:2rem; right:var(--pad); display:flex; align-items:center; gap:.8rem;
  color:var(--fog); writing-mode:vertical-rl; z-index:2;
}
.scroll-cue .bar{ width:1px; height:54px; background:linear-gradient(var(--red),transparent); position:relative; }
.scroll-cue .bar::after{ content:""; position:absolute; top:0; left:0; width:1px; height:18px; background:var(--red); animation:cue 2.2s var(--ease) infinite; }
@keyframes cue{ 0%{transform:translateY(0);opacity:1} 70%{transform:translateY(36px);opacity:0} 100%{opacity:0} }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--red); color:#fff; overflow:hidden; padding-block:.95rem;
  border-block:1px solid var(--red-deep); position:relative; z-index:5;
}
.marquee-track{ display:flex; gap:0; width:max-content; animation:scrollX 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{
  font-family:var(--font-display); font-stretch:expanded; font-weight:800; text-transform:uppercase;
  font-size:1.05rem; letter-spacing:.02em; padding-inline:1.5rem; display:inline-flex; align-items:center; gap:1.5rem;
  white-space:nowrap;
}
.marquee-track span::after{ content:"✳"; font-size:.8rem; opacity:.7; }
@keyframes scrollX{ to{ transform:translateX(-50%); } }

/* ============================================================
   SECTION TITLES
   ============================================================ */
.sec-head{ position:relative; z-index:1; margin-bottom:clamp(2.5rem,5vw,4rem); }
.sec-head .kicker{ margin-bottom:1.1rem; }
.sec-head h2{
  font-family:var(--font-display); font-weight:800; font-stretch:expanded; text-transform:uppercase;
  letter-spacing:-.02em; line-height:.96; font-size:clamp(2.1rem,5.5vw,4.4rem);
}
.bg-concrete .sec-head h2{ color:var(--ink); }
.sec-head .lead{ margin-top:1.3rem; max-width:52ch; font-size:1.06rem; font-weight:300; }
.bg-ink .sec-head .lead{ color:var(--fog); }
.bg-concrete .sec-head .lead{ color:var(--slate); }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center; position:relative; z-index:1; }
.about-copy p{ color:var(--slate); margin-bottom:1.1rem; max-width:48ch; }
.about-copy p.lead-p{ color:var(--ink); font-size:1.3rem; font-weight:500; line-height:1.45; font-family:var(--font-display); font-stretch:semi-expanded; letter-spacing:-.01em; }
.about-copy .signature{ margin-top:2rem; display:flex; align-items:center; gap:1rem; }
.about-copy .signature .mono{ color:var(--red); }

.about-figure{ position:relative; }
.about-figure .panel{
  position:relative; background:#fff; aspect-ratio:4/4.3; overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% 100%,32px 100%,0 calc(100% - 32px));
  box-shadow:0 24px 60px rgba(13,14,16,.14);
}
.about-figure .panel img{ position:absolute; inset:0; width:100%; height:100%;
  object-fit:contain; object-position:bottom center; z-index:1; }
/* subtle brand baseline instead of overlay text/gradient */
.about-figure .panel::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:6px; z-index:2;
  background:var(--red);
}
.about-figure .badge{
  position:absolute; top:-22px; right:-14px; z-index:3; background:var(--red); color:#fff;
  width:118px; height:118px; border-radius:50%; display:grid; place-content:center; text-align:center;
  transform:rotate(-8deg); box-shadow:0 18px 40px var(--red-glow);
}
.about-figure .badge b{ font-family:var(--font-display); font-stretch:expanded; font-weight:900; font-size:2.1rem; line-height:.9; display:block; }
.about-figure .badge span{ font-family:var(--font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; }

/* leadership cards */
.team{
  margin-top:clamp(2.5rem,6vh,4.5rem);
  display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.2rem;
}
.team-card{
  background:#fff; border:1px solid var(--line-light);
  padding:clamp(1.5rem,2.4vw,2.2rem);
  clip-path:polygon(0 0,100% 0,100% 100%,16px 100%,0 calc(100% - 16px));
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s;
}
.team-card:hover{ transform:translateY(-4px); border-color:var(--red); box-shadow:0 18px 44px rgba(13,14,16,.12); }
.team-name{
  font-family:var(--font-display); font-stretch:expanded; font-weight:800;
  text-transform:uppercase; letter-spacing:-.01em; line-height:1.1;
  font-size:clamp(1.1rem,1.9vw,1.55rem); color:var(--ink);
}
.team-role{ color:var(--red); margin-top:.45rem; }
.team-quali{ list-style:none; margin-top:1.1rem; color:var(--slate); font-size:.95rem; line-height:1.75; }
.team-contact{
  margin-top:1.3rem; padding-top:1.1rem; border-top:1px solid var(--line-light);
  display:flex; flex-direction:column; gap:.4rem;
  font-family:var(--font-mono); font-size:.8rem; letter-spacing:.02em;
}
.team-contact a{ color:var(--ink); transition:color .25s; }
.team-contact a:hover{ color:var(--red); }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-light); margin-top:clamp(3rem,6vw,5rem); border:1px solid var(--line-light); position:relative; z-index:1; }
.stat{ background:var(--concrete); padding:2rem 1.6rem; }
.stat .num{ font-family:var(--font-display); font-stretch:expanded; font-weight:900; font-size:clamp(2.4rem,5vw,3.6rem); line-height:1; color:var(--ink); letter-spacing:-.03em; }
.stat .num .suf{ color:var(--red); }
.stat .lbl{ margin-top:.6rem; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--slate); }

/* ============================================================
   SERVICES
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); position:relative; z-index:1; }
.svc{
  background:var(--ink); padding:clamp(1.8rem,3vw,2.8rem); min-height:300px;
  display:flex; flex-direction:column; position:relative; overflow:hidden; transition:background .45s var(--ease);
}
.svc::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--red); transition:width .5s var(--ease); }
.svc:hover{ background:var(--ink-2); }
.svc:hover::before{ width:100%; }
.svc .idx{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.2em; color:var(--red); }
.svc .ico{ margin-top:1.4rem; width:46px; height:46px; color:var(--concrete); transition:color .4s, transform .5s var(--ease); }
.svc:hover .ico{ color:var(--red); transform:translateY(-4px); }
.svc h3{ margin-top:auto; font-family:var(--font-display); font-stretch:expanded; font-weight:800; text-transform:uppercase; font-size:1.5rem; letter-spacing:-.01em; line-height:1; }
.svc p{ margin-top:.9rem; color:var(--fog); font-size:.96rem; font-weight:300; max-width:34ch; }
.svc .arrow{ margin-top:1.4rem; width:34px; height:34px; display:grid; place-content:center; color:var(--fog); transition:.4s var(--ease); }
.svc:hover .arrow{ color:var(--red); transform:translate(4px,-4px); }

/* ============================================================
   REFERENCES
   ============================================================ */
.ref-grid{
  display:grid; gap:14px; position:relative; z-index:1;
  grid-template-columns:repeat(12,1fr); grid-auto-rows:minmax(150px,auto);
}
.ref{ position:relative; overflow:hidden; background:var(--ink-2); }
.ref img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease-out); }
.ref:hover img{ transform:scale(1.08); }
.ref::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 40%, rgba(13,14,16,.82)); opacity:.85; transition:opacity .4s; }
.ref:hover::after{ opacity:1; }
.ref .meta{ position:absolute; left:1.2rem; bottom:1.1rem; right:1.2rem; z-index:2; transform:translateY(8px); opacity:.92; transition:transform .5s var(--ease); }
.ref:hover .meta{ transform:translateY(0); }
.ref .meta .cat{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.ref .meta .ttl{ font-family:var(--font-display); font-stretch:expanded; font-weight:800; text-transform:uppercase; font-size:1.15rem; color:#fff; line-height:1.05; margin-top:.25rem; }
.ref .num{ position:absolute; top:1rem; right:1.1rem; z-index:2; font-family:var(--font-mono); font-size:.7rem; color:rgba(255,255,255,.7); letter-spacing:.1em; }

/* bento spans */
.ref.r-tall{ grid-column:span 5; grid-row:span 2; }
.ref.r-wide{ grid-column:span 7; grid-row:span 1; }
.ref.r-mid{ grid-column:span 4; grid-row:span 1; }
.ref.r-sq{ grid-column:span 3; grid-row:span 1; }

/* ============================================================
   CAREER (full-bleed band)
   ============================================================ */
.career{ position:relative; overflow:hidden; isolation:isolate; }
.career-media{ position:absolute; inset:0; z-index:-2; }
.career-media img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; }
.career::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, rgba(13,14,16,.92), rgba(13,14,16,.55) 60%, rgba(226,0,26,.35)); }
.career-inner{ padding-block:clamp(5rem,12vh,9rem); position:relative; z-index:1;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2.5rem,5vw,5rem); align-items:center; }
.career-intro{ max-width:52ch; }
.career-inner h2{ font-family:var(--font-display); font-stretch:expanded; font-weight:900; text-transform:uppercase; letter-spacing:-.02em; line-height:.92; font-size:clamp(2.3rem,5.5vw,4.6rem); }
.career-inner h2 em{ font-style:normal; color:var(--red); }
.career-intro p{ margin-top:1.4rem; color:rgba(243,239,232,.85); font-size:1.1rem; font-weight:300; max-width:46ch; }
.career-actions{ margin-top:2rem; display:flex; gap:1rem; flex-wrap:wrap; }

/* benefit chips */
.perks{ list-style:none; display:flex; flex-wrap:wrap; gap:.55rem; margin-top:1.8rem; }
.perks li{
  font-family:var(--font-mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(243,239,232,.88); padding:.5rem .8rem; border:1px solid var(--line);
  background:rgba(13,14,16,.4); backdrop-filter:blur(4px);
}
.perks li::before{ content:"›"; color:var(--red); margin-right:.45rem; font-weight:700; }

/* job list */
.jobs{ background:rgba(13,14,16,.55); backdrop-filter:blur(10px); border:1px solid var(--line);
  padding:1.6rem clamp(1.2rem,2.5vw,2rem); }
.jobs-head{ display:flex; justify-content:space-between; align-items:center; padding-bottom:1.1rem; margin-bottom:.4rem; border-bottom:1px solid var(--line); }
.jobs-head .mono{ color:var(--fog); }
.jobs-head .mono:last-child{ color:var(--red); }
.job{ display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.15rem .4rem; border-bottom:1px solid var(--line); position:relative; transition:padding .35s var(--ease); }
.job:last-child{ border-bottom:none; }
.job::before{ content:""; position:absolute; left:calc(-1 * clamp(1.2rem,2.5vw,2rem)); top:0; bottom:0; width:3px; background:var(--red); transform:scaleY(0); transform-origin:center; transition:transform .35s var(--ease); }
.job:hover{ padding-left:1rem; }
.job:hover::before{ transform:scaleY(1); }
.job-main{ display:flex; flex-direction:column; gap:.25rem; }
.job-title{ font-family:var(--font-display); font-stretch:expanded; font-weight:800; text-transform:uppercase; font-size:1.35rem; line-height:1; color:#fff; transition:color .3s; }
.job:hover .job-title{ color:var(--red); }
.job-tag{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--fog); }
.job-go{ width:42px; height:42px; flex-shrink:0; display:grid; place-content:center; border:1px solid var(--line); color:var(--fog); transition:.35s var(--ease); }
.job-go svg{ width:17px; height:17px; }
.job:hover .job-go{ background:var(--red); border-color:var(--red); color:#fff; transform:translateX(4px); }

/* WhatsApp button variant */
.btn--wa{ --bg:#1faa53; --fg:#fff; }
.btn--wa::before{ background:#178a43; }
.btn--wa:hover{ color:#fff; }
.btn--wa svg{ width:18px; height:18px; }

/* floating WhatsApp */
.wa-fab{
  position:fixed; right:clamp(1rem,3vw,2rem); bottom:clamp(1rem,3vw,2rem); z-index:900;
  display:inline-flex; align-items:center; gap:0; background:#1faa53; color:#fff;
  height:58px; border-radius:999px; padding:0 18px; overflow:hidden;
  box-shadow:0 14px 36px rgba(31,170,83,.4), 0 4px 12px rgba(0,0,0,.3);
  transition:transform .35s var(--ease), background .3s, box-shadow .3s;
}
.wa-fab svg{ width:28px; height:28px; flex-shrink:0; }
.wa-fab-label{ max-width:0; opacity:0; white-space:nowrap; overflow:hidden;
  font-family:var(--font-mono); font-weight:600; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase;
  transition:max-width .4s var(--ease), opacity .3s, margin-left .4s var(--ease); }
.wa-fab:hover{ background:#178a43; transform:translateY(-3px); box-shadow:0 18px 44px rgba(31,170,83,.5); }
.wa-fab:hover .wa-fab-label{ max-width:120px; opacity:1; margin-left:10px; }
.wa-fab::after{ content:""; position:absolute; inset:0; border-radius:999px; box-shadow:0 0 0 0 rgba(31,170,83,.5); animation:waPulse 2.6s var(--ease) infinite; }
@keyframes waPulse{ 0%{ box-shadow:0 0 0 0 rgba(31,170,83,.45); } 70%{ box-shadow:0 0 0 16px rgba(31,170,83,0); } 100%{ box-shadow:0 0 0 0 rgba(31,170,83,0); } }
@media (prefers-reduced-motion:reduce){ .wa-fab::after{ animation:none; } }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; min-height:600px; position:relative; z-index:1; }
.contact-info{ background:var(--ink-2); padding:clamp(2.2rem,5vw,4.5rem); border:1px solid var(--line); }
.contact-info .sheet-tag{ display:flex; justify-content:space-between; align-items:center; border-bottom:1px solid var(--line); padding-bottom:1rem; margin-bottom:2.2rem; }
.contact-info .sheet-tag .mono{ color:var(--fog); }
.contact-info .sheet-tag .dot{ width:9px; height:9px; background:var(--red); border-radius:50%; box-shadow:0 0 0 4px var(--red-glow); }
.cinfo-row{ display:grid; grid-template-columns:120px 1fr; gap:1rem; padding-block:1.25rem; border-bottom:1px solid var(--line); align-items:start; }
.cinfo-row:last-of-type{ border-bottom:none; }
.cinfo-row .k{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red); padding-top:.3rem; }
.cinfo-row .v{ font-size:1.12rem; color:var(--concrete); }
.cinfo-row .v a{ transition:color .3s; }
.cinfo-row .v a:hover{ color:var(--red); }
.cinfo-row .v small{ display:block; color:var(--fog); font-size:.85rem; margin-top:.3rem; }
.contact-note{ margin-top:1.8rem; padding:1.1rem 1.3rem; background:rgba(226,0,26,.08); border-left:3px solid var(--red); font-size:.95rem; color:rgba(243,239,232,.9); }
.contact-map{ position:relative; background:var(--ink-3); }
.contact-map iframe{ width:100%; height:100%; border:0; filter:grayscale(.4) contrast(1.05) brightness(.85); }
.contact-map .pin-badge{ position:absolute; top:1.2rem; right:1.2rem; z-index:2; background:var(--ink); color:#fff; padding:.7rem 1.1rem; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; border-right:3px solid var(--red); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#08090a; padding-top:clamp(3.5rem,7vw,5.5rem); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; border-bottom:1px solid var(--line); }
.foot-brand img{ height:50px; filter:brightness(0) invert(1); margin-bottom:1.3rem; }
.foot-brand p{ color:var(--fog); max-width:32ch; font-weight:300; font-size:.95rem; }
.foot-col h4{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:1.1rem; }
.foot-col a, .foot-col p{ display:block; color:var(--fog); font-size:.96rem; padding-block:.35rem; transition:color .3s, padding-left .3s; }
.foot-col a:hover{ color:#fff; padding-left:.4rem; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; padding-block:1.8rem; }
.foot-bottom .mono{ color:var(--slate); font-size:.68rem; }
.foot-bottom a{ color:var(--fog); }
.foot-bottom a:hover{ color:var(--red); }
.to-top{ display:inline-flex; align-items:center; gap:.6rem; color:var(--fog); font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; transition:color .3s; }
.to-top:hover{ color:var(--red); }
.to-top svg{ width:14px; height:14px; transition:transform .3s; }
.to-top:hover svg{ transform:translateY(-3px); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
/* progressive enhancement: only hide when JS is active, so content
   is never permanently invisible if JS fails to load */
.js .reveal{ opacity:0; transform:translateY(38px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.js .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; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
  .hero-media img{ transform:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .about-grid{ grid-template-columns:1fr; }
  .about-figure{ max-width:440px; }
  .career-inner{ grid-template-columns:1fr; gap:2.5rem; }
  .career-intro{ max-width:none; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .contact-grid{ grid-template-columns:1fr; }
  .contact-map{ min-height:380px; }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .ref.r-tall{ grid-column:span 7; grid-row:span 2; }
  .ref.r-wide{ grid-column:span 5; }
  .ref.r-mid{ grid-column:span 6; }
  .ref.r-sq{ grid-column:span 6; }
}
/* collapse to burger before the horizontal nav gets cramped */
@media (max-width:1080px){
  .nav{ display:none; }
  .cta-phone.desktop{ display:none; }
  .burger{ display:block; }
}

@media (max-width:720px){
  .hero-top{ display:none; }
  .scroll-cue{ display:none; }
  .svc-grid{ grid-template-columns:1fr; }
  .ref-grid{ grid-template-columns:repeat(2,1fr); }
  .ref.r-tall,.ref.r-wide,.ref.r-mid,.ref.r-sq{ grid-column:span 2; grid-row:span 1; min-height:230px; }
  .ref.r-tall{ grid-row:span 1; }
  .foot-top{ grid-template-columns:1fr; }
  .cinfo-row{ grid-template-columns:1fr; gap:.3rem; }
}
@media (max-width:420px){
  .stats{ grid-template-columns:1fr; }
}
