/* ============================================================
   DAL Security Service Unit — Design System
   Modern / sharp / tech-forward
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Archivo:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  /* brand */
  --navy:        #0A1A2F;
  --navy-900:    #060f1c;
  --navy-800:    #0d2138;
  --navy-700:    #12293f;
  --navy-line:   #1d3450;
  --black:       #000000;
  --gold:        #A38F6B;
  --gold-bright: #c2ac82;
  --charcoal:    #2E2E2E;

  --paper:       #F4F3EF;
  --paper-2:     #ECEAE3;
  --white:       #FFFFFF;
  --ink:         #11161d;
  --ink-soft:    #4a5360;

  --line:        rgba(10,26,47,.12);
  --line-dark:   rgba(255,255,255,.12);

  /* type */
  --display: 'Space Grotesk', system-ui, sans-serif;
  --body:    'Archivo', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

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

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; margin:0; line-height:1.02; letter-spacing:-.02em; }
.display{
  font-size:clamp(2.6rem, 6.4vw, 6.2rem);
  font-weight:600;
  letter-spacing:-.035em;
  line-height:.96;
}
.h-sec{ font-size:clamp(2rem, 4.2vw, 3.6rem); letter-spacing:-.03em; }
p{ margin:0 0 1em; }
.lead{ font-size:clamp(1.05rem,1.4vw,1.3rem); color:var(--ink-soft); line-height:1.6; }

/* mono microlabel */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.no-rule::before{ display:none; }

/* ---------- layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,9vw,140px); }
.dark{ background:var(--navy); color:var(--white); }
.dark .lead{ color:rgba(255,255,255,.62); }
.dark .eyebrow{ color:var(--gold); }
.paper-2{ background:var(--paper-2); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--mono); font-size:.78rem; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase;
  padding:1.05em 1.7em; border:1px solid transparent;
  background:var(--gold); color:var(--navy);
  transition:.25s ease; white-space:nowrap;
}
.btn .ar{ transition:transform .25s ease; }
.btn:hover{ background:var(--gold-bright); }
.btn:hover .ar{ transform:translateX(4px); }
.btn.ghost{ background:transparent; color:var(--navy); border-color:var(--line); }
.dark .btn.ghost{ color:#fff; border-color:rgba(255,255,255,.28); }
.btn.ghost:hover{ border-color:var(--gold); color:var(--gold); background:transparent; }
.btn.solid-navy{ background:var(--navy); color:#fff; }
.btn.solid-navy:hover{ background:var(--navy-800); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:80;
  height:84px;
  display:flex; align-items:center;
  transition:background .3s ease, height .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.site-header .wrap{ display:flex; align-items:center; gap:2rem; width:100%; }
.brand{ display:flex; align-items:center; gap:.85rem; margin-right:auto; }
.brand img.brand-mark{ height:30px; width:auto; transition:.3s ease; }
.brand .brand-txt{ display:flex; flex-direction:column; line-height:1; }
.brand .bt-1{ font-family:var(--display); font-weight:600; font-size:.95rem; letter-spacing:.02em; color:#fff; transition:color .3s; }
.brand .bt-2{ font-family:var(--mono); font-size:.58rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-top:3px; white-space:nowrap; }

.main-nav{ display:flex; align-items:center; gap:2px; }
.main-nav a{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.78); padding:.6em .9em; transition:color .2s; position:relative;
}
.main-nav a:hover,.main-nav a.active{ color:#fff; }
.main-nav a.active::after{
  content:""; position:absolute; left:.9em; right:.9em; bottom:.2em; height:1px; background:var(--gold);
}

.header-tools{ display:flex; align-items:center; gap:1rem; }
.lang{ display:flex; font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; border:1px solid rgba(255,255,255,.22); }
.lang button{ background:none; border:0; color:rgba(255,255,255,.6); padding:.5em .7em; transition:.2s; }
.lang button.on{ background:var(--gold); color:var(--navy); }

/* header scrolled / solid (on light pages) */
.site-header.solid{ background:rgba(244,243,239,.92); backdrop-filter:blur(12px); border-color:var(--line); height:72px; }
.site-header.solid .brand .bt-1{ color:var(--navy); }
.site-header.solid .main-nav a{ color:var(--ink-soft); }
.site-header.solid .main-nav a:hover,.site-header.solid .main-nav a.active{ color:var(--navy); }
.site-header.solid .lang{ border-color:var(--line); }
.site-header.solid .lang button{ color:var(--ink-soft); }
.site-header.solid .lang button.on{ background:var(--navy); color:#fff; }

/* pages with light hero get solid header always */
.lighttop .site-header{ background:rgba(244,243,239,.92); backdrop-filter:blur(12px); border-color:var(--line); }
.lighttop .brand .bt-1{ color:var(--navy); }
.lighttop .main-nav a{ color:var(--ink-soft); }
.lighttop .main-nav a:hover,.lighttop .main-nav a.active{ color:var(--navy); }
.lighttop .lang{ border-color:var(--line); }
.lighttop .lang button{ color:var(--ink-soft); }
.lighttop .lang button.on{ background:var(--navy); color:#fff; }
.lighttop .brand .logo-white{ display:none; }
.brand .logo-navy{ display:none; }
.lighttop .brand .logo-navy{ display:block; }
.site-header.solid .brand .logo-white{ display:none; }
.site-header.solid .brand .logo-navy{ display:block; }

/* burger */
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; }
.burger span{ width:22px; height:2px; background:#fff; transition:.3s; }
.solid .burger span,.lighttop .burger span{ background:var(--navy); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--navy-900); color:rgba(255,255,255,.7); }
.foot-grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:2.5rem;
  padding-block:clamp(56px,7vw,90px);
  border-bottom:1px solid var(--line-dark);
}
.foot-brand img.crest{ height:64px; margin-bottom:1.4rem; }
.foot-brand .fb-name{ font-family:var(--display); color:#fff; font-size:1.15rem; font-weight:600; }
.foot-col h5{ font-family:var(--mono); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 1.2rem; font-weight:500; }
.foot-col a, .foot-col p{ display:block; font-size:.92rem; color:rgba(255,255,255,.66); margin:0 0 .7rem; transition:color .2s; }
.foot-col a:hover{ color:var(--gold); }
.foot-bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-block:1.6rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; color:rgba(255,255,255,.4); text-transform:uppercase; }
.foot-bottom a{ color:rgba(255,255,255,.55); }
.foot-bottom a:hover{ color:var(--gold); }

/* ============================================================
   SHARED COMPONENTS
   ============================================================ */
/* page hero (interior) */
.page-hero{ position:relative; padding-top:clamp(150px,18vh,210px); padding-bottom:clamp(54px,7vw,90px); overflow:hidden; }
.page-hero .crest-bg{
  position:absolute; right:-4%; top:50%; transform:translateY(-50%);
  width:min(46vw,560px); opacity:.05; pointer-events:none;
}
.page-hero.dark .crest-bg{ opacity:.07; }
.page-hero h1{ font-size:clamp(2.6rem,6vw,5rem); max-width:14ch; }
.page-hero .lead{ max-width:54ch; margin-top:1.4rem; }
.crumb{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:1.6rem; display:flex; gap:.6em; }
.crumb .sep{ color:rgba(255,255,255,.3); }

/* stat row */
.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); }
.stat{ background:var(--navy); padding:2rem 1.8rem; }
.stat .num{ font-family:var(--display); font-size:clamp(2.2rem,3.4vw,3rem); color:#fff; font-weight:600; letter-spacing:-.02em; }
.stat .num .u{ color:var(--gold); }
.stat .lbl{ font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:.5rem; }

/* generic grid */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }

/* image placeholder */
.ph{
  position:relative; background:
    repeating-linear-gradient(135deg, rgba(10,26,47,.05) 0 2px, transparent 2px 11px),
    var(--paper-2);
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-soft); overflow:hidden;
}
.ph.on-dark{ background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 2px, transparent 2px 11px),
    var(--navy-800);
  border-color:var(--line-dark); }
.ph .ph-tag{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); padding:.5em .8em; border:1px solid var(--line); background:var(--paper); }
.ph.on-dark .ph-tag{ color:rgba(255,255,255,.55); border-color:var(--line-dark); background:var(--navy-900); }
/* filled with generated key-visual */
.ph.filled{ padding:0; border-color:var(--line-dark); }
.phi{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.ratio-43{ aspect-ratio:4/3; }
.ratio-11{ aspect-ratio:1/1; }
.ratio-169{ aspect-ratio:16/9; }
.ratio-34{ aspect-ratio:3/4; }

/* service cards */
.svc-card{
  position:relative; background:var(--white); border:1px solid var(--line);
  padding:2.2rem 2rem 2.4rem; transition:.3s ease; overflow:hidden;
  display:flex; flex-direction:column; min-height:300px;
}
.svc-card .idx{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; color:var(--gold); }
.svc-card h3{ font-size:1.5rem; margin:1.4rem 0 .8rem; }
.svc-card p{ font-size:.95rem; color:var(--ink-soft); margin:0; }
.svc-card .go{ margin-top:auto; padding-top:1.6rem; font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--navy); display:inline-flex; gap:.6em; align-items:center; }
.svc-card::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--gold); transition:width .35s ease; }
.svc-card:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -28px rgba(10,26,47,.4); }
.svc-card:hover::after{ width:100%; }
.svc-card .ic{ width:34px; height:34px; color:var(--navy); }

/* feature list with rules */
.rules{ border-top:1px solid var(--line); }
.rule-item{ display:grid; grid-template-columns:auto 1fr auto; gap:1.5rem; align-items:start; padding:1.8rem 0; border-bottom:1px solid var(--line); }
.rule-item .ri-num{ font-family:var(--mono); font-size:.78rem; color:var(--gold); padding-top:.3rem; }
.rule-item h4{ font-size:1.3rem; margin-bottom:.4rem; }
.rule-item p{ margin:0; color:var(--ink-soft); font-size:.95rem; max-width:62ch; }

/* CTA band */
.cta-band{ position:relative; overflow:hidden; }
.cta-band .crest-bg{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:min(70vw,720px); opacity:.045; pointer-events:none; }

/* reveal anim */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }

/* utility */
.mono{ font-family:var(--mono); }
.gold{ color:var(--gold); }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:2rem; } .mt-l{ margin-top:3rem; }
.center{ text-align:center; }
.maxw-60{ max-width:60ch; } .mx-auto{ margin-inline:auto; }
.hairline{ height:1px; background:var(--line); border:0; margin:0; }
.dark .hairline{ background:var(--line-dark); }

/* lang visibility handled by JS swapping textContent */

/* section background images (Ihsan's request) */
.sec-bg{ background-size:cover; background-position:center; background-repeat:no-repeat; }
.sec-bg.dark .stat-row{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.16); }
.sec-bg.dark .stat{ background:rgba(10,26,47,.62); backdrop-filter:blur(2px); }
.stat-row.cols-3{ grid-template-columns:repeat(3,1fr); }
@media (max-width:980px){ .stat-row.cols-3{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .stat-row.cols-3{ grid-template-columns:1fr; } }

/* legal pages (Impressum / Datenschutz) */
.legal{ max-width:62rem; }
.legal .lead{ margin-bottom:2.4rem; }
.legal h2{ font-size:1.5rem; margin:2.6rem 0 .9rem; letter-spacing:-.01em; }
.legal h3{ font-size:1.1rem; margin:1.8rem 0 .6rem; }
.legal p, .legal li{ color:var(--ink-soft); font-size:1rem; line-height:1.7; }
.legal p{ margin:0 0 1em; }
.legal ul{ margin:0 0 1.2em; padding-left:1.2em; }
.legal li{ margin-bottom:.4em; }
.legal a{ color:var(--navy); border-bottom:1px solid var(--gold); }
.legal a:hover{ color:var(--gold); }
.legal .addr{ font-style:normal; color:var(--ink); line-height:1.7; }
.legal .todo{ background:rgba(163,143,107,.12); border:1px solid rgba(163,143,107,.45); color:var(--charcoal); padding:.15em .5em; font-family:var(--mono); font-size:.82em; }
.legal hr{ border:0; height:1px; background:var(--line); margin:2.4rem 0; }
.legal .note-box{ background:var(--paper-2); border-left:3px solid var(--gold); padding:1.2rem 1.4rem; margin:0 0 2rem; }
.legal .note-box p{ margin:0; font-size:.92rem; }

.crumb .sep{ color:rgba(10,26,47,.3); }
.dark .crumb .sep{ color:rgba(255,255,255,.3); }

/* ---- ticks list ---- */
.ticks{ list-style:none; padding:0; margin:1.8rem 0 0; display:grid; gap:.9rem; }
.ticks li{ display:grid; grid-template-columns:auto 1fr; gap:.9rem; align-items:start; font-size:1rem; color:var(--ink-soft); }
.ticks li::before{ content:""; width:18px; height:18px; margin-top:.2rem; background:var(--gold); -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E") center/contain no-repeat; mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E") center/contain no-repeat; }
.dark .ticks li{ color:rgba(255,255,255,.7); }

/* ---- service detail ---- */
.svc-detail{ position:relative; overflow:hidden; }
.svc-detail .big-idx{ position:absolute; top:1rem; right:2rem; font-family:var(--display); font-weight:600; font-size:clamp(6rem,16vw,14rem); line-height:.8; color:var(--navy); opacity:.04; pointer-events:none; }
.svc-tag{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); display:flex; gap:.7em; align-items:center; }

/* ---- process steps ---- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); margin-top:3rem; }
.step{ background:var(--navy); padding:2.2rem 1.8rem 2.6rem; position:relative; }
.step .s-num{ font-family:var(--mono); font-size:.8rem; color:var(--gold); letter-spacing:.1em; }
.step h4{ color:#fff; font-size:1.25rem; margin:1.4rem 0 .7rem; }
.step p{ color:rgba(255,255,255,.6); font-size:.92rem; margin:0; }

/* ---- values grid ---- */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-top:3rem; }
.value{ background:var(--white); padding:2.4rem 2rem; }
.value .v-ic{ width:30px; height:30px; color:var(--gold); margin-bottom:1.4rem; }
.value h4{ font-size:1.3rem; margin-bottom:.6rem; }
.value p{ color:var(--ink-soft); font-size:.95rem; margin:0; }

/* ---- timeline ---- */
.timeline{ margin-top:1rem; border-left:1px solid var(--line-dark); padding-left:2rem; display:grid; gap:2.4rem; }
.tl-item{ position:relative; }
.tl-item::before{ content:""; position:absolute; left:calc(-2rem - 5px); top:.4rem; width:9px; height:9px; background:var(--gold); border-radius:50%; }
.tl-item .tl-year{ font-family:var(--mono); font-size:.8rem; color:var(--gold); letter-spacing:.1em; }
.tl-item h4{ color:#fff; font-size:1.3rem; margin:.5rem 0 .5rem; }
.tl-item p{ color:rgba(255,255,255,.6); margin:0; max-width:52ch; }

/* ---- jobs ---- */
.job{ display:grid; grid-template-columns:auto 1fr auto auto; gap:1.5rem; align-items:center; padding:1.8rem 0; border-top:1px solid var(--line); transition:.25s; }
.job:last-child{ border-bottom:1px solid var(--line); }
.job .j-idx{ font-family:var(--mono); font-size:.78rem; color:var(--gold); }
.job h4{ font-size:1.35rem; }
.job .j-meta{ font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
.job .j-go{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--navy); display:inline-flex; gap:.5em; align-items:center; white-space:nowrap; }
.job:hover{ background:var(--white); padding-inline:1.4rem; }
.job:hover .j-go{ color:var(--gold); }

/* ---- forms ---- */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,5rem); align-items:start; }
.field{ display:flex; flex-direction:column; gap:.5rem; margin-bottom:1.3rem; }
.field label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.field input,.field select,.field textarea{
  font-family:var(--body); font-size:1rem; color:var(--ink);
  background:var(--white); border:1px solid var(--line); padding:.9em 1em; border-radius:0; transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(163,143,107,.15); }
.field input.err,.field select.err,.field textarea.err{ border-color:#c0492f; box-shadow:0 0 0 3px rgba(192,73,47,.15); }
.field textarea{ resize:vertical; min-height:130px; }
.form-ok{ display:none; margin-top:1rem; padding:1em 1.2em; border:1px solid var(--gold); background:rgba(163,143,107,.12); color:var(--gold); font-family:var(--mono); font-size:.78rem; letter-spacing:.03em; line-height:1.5; }
.form-ok.show{ display:block; animation:okin .4s ease; }
@keyframes okin{ from{ opacity:0; transform:translateY(6px); } to{ opacity:1; transform:none; } }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.3rem; }
.info-card{ background:var(--navy); color:#fff; padding:2.4rem; }
.info-card h3{ color:#fff; font-size:1.4rem; margin-bottom:1.4rem; }
.info-line{ display:grid; grid-template-columns:auto 1fr; gap:1rem; padding:1rem 0; border-bottom:1px solid var(--line-dark); }
.info-line:last-child{ border-bottom:0; }
.info-line .il-k{ font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.info-line .il-v{ color:rgba(255,255,255,.85); font-size:.98rem; }
.info-line .il-v a{ color:#fff; }
.map-ph{ aspect-ratio:16/10; margin-top:0; }

@media (max-width:980px){
  .steps{ grid-template-columns:1fr 1fr; }
  .values{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  .job{ grid-template-columns:auto 1fr; }
  .job .j-meta,.job .j-go{ grid-column:2; }
  .steps{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; flex-direction:column; justify-content:center; overflow:hidden; padding-top:84px; }
.hero-crest{
  position:absolute; right:-6%; top:50%; transform:translateY(-50%);
  width:min(58vw,720px); opacity:.06; pointer-events:none; filter:saturate(0);
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(163,143,107,.10), transparent 55%),
    linear-gradient(180deg, var(--navy-900), var(--navy) 40%, var(--navy-800));
  z-index:-1;
}
.hero-inner{ position:relative; z-index:2; padding-block:3rem; }
.hero-coord{ font-size:.68rem; letter-spacing:.22em; color:rgba(255,255,255,.4); margin-bottom:2.2rem; }
.hero h1{ color:#fff; }
.hero-cta{ display:flex; gap:.9rem; flex-wrap:wrap; margin-top:2.4rem; }
.hero-foot{ position:relative; z-index:2; display:flex; gap:2.5rem; flex-wrap:wrap; padding-top:2.5rem; margin-top:auto; border-top:1px solid var(--line-dark); }
.hf-item{ display:flex; align-items:center; gap:.7rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.6); }
.hf-item .gold{ font-weight:700; }

/* ============================================================
   SECTORS
   ============================================================ */
.sectors{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.sector{ background:var(--paper); padding:2.4rem 1.6rem; display:flex; align-items:center; min-height:120px; transition:.3s ease; }
.sector span{ font-family:var(--display); font-weight:500; font-size:1.15rem; letter-spacing:-.01em; }
.sector:hover{ background:var(--navy); }
.sector:hover span{ color:#fff; }

/* ============================================================
   APPROACH — dark rule items
   ============================================================ */
.rules-dark .rule-item{ border-color:var(--line-dark); }
.rules-dark .rule-item:first-child{ border-top:1px solid var(--line-dark); }
.rules-dark h4{ color:#fff; }
.rules-dark p{ color:rgba(255,255,255,.6); }

/* ============================================================
   CAREERS BAND
   ============================================================ */
.career-points{ display:flex; flex-direction:column; gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); }
.cp{ background:var(--navy-800); padding:1.3rem 1.6rem; display:flex; align-items:center; gap:1rem; font-size:1.02rem; }
.cp .gold{ font-family:var(--mono); font-size:1.1rem; }

@media (max-width:980px){
  .sectors{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .hero-foot{ gap:1.2rem 2rem; }
}
@media (max-width:520px){
  .sectors{ grid-template-columns:1fr; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .grid-2{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:1fr 1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:2rem; }
  .stat-row{ grid-template-columns:1fr 1fr; }
}
@media (max-width:1040px){
  .main-nav:not(.open), .header-tools .desk-cta{ display:none; }
  .burger{ display:flex; }
  /* mobile menu */
  .main-nav.open{
    display:flex; flex-direction:column; position:fixed; inset:84px 0 auto 0;
    background:var(--navy); padding:1.5rem var(--gutter) 2rem; gap:0; border-bottom:1px solid var(--line-dark); align-items:flex-start;
  }
  .main-nav.open a{ width:100%; padding:1em 0; border-bottom:1px solid var(--line-dark); color:#fff; font-size:.9rem; }
  .main-nav.open a.active::after{ display:none; }
  .lighttop .main-nav.open a, .solid .main-nav.open a{ color:#fff; }
}
@media (max-width:760px){
  .grid-3{ grid-template-columns:1fr; }
  .rule-item{ grid-template-columns:auto 1fr; }
  .rule-item .ri-go{ display:none; }
}
@media (max-width:520px){
  .foot-grid{ grid-template-columns:1fr; }
  .stat-row{ grid-template-columns:1fr; }
}
