/* =========================================================
   HavenCore Technologies — Stylesheet
   Design system: "Engineering Drawing" — blueprint annotation
   marks (corner brackets, dimension rules, sheet index) applied
   to real plant photography.
   ========================================================= */

/* ---------- Design tokens ---------- */
:root{
  /* color */
  --navy-950:#08111F;
  --navy-900:#0D1F38;
  --navy-800:#122A4B;
  --navy-700:#1B3A66;
  --navy-600:#27507F;
  --blue-500:#2F7FD6;
  --blue-400:#5B9EE6;
  --gold-500:#F2A93B;
  --gold-600:#DB8F1F;
  --green-500:#48AE63;
  --green-600:#379150;
  --paper-0:#FFFFFF;
  --paper-50:#F6F7F9;
  --paper-100:#EDF0F4;
  --paper-200:#E2E6EC;
  --ink-900:#101521;
  --ink-700:#2B3342;
  --ink-500:#5C6577;
  --ink-300:#8B93A3;
  --line:#DDE2E9;
  --line-dark:rgba(255,255,255,.14);
  --line-dark-soft:rgba(255,255,255,.08);

  /* type */
  --f-display:'Space Grotesk', sans-serif;
  --f-body:'Inter', sans-serif;
  --f-mono:'IBM Plex Mono', monospace;

  /* layout */
  --maxw:1280px;
  --gutter:clamp(20px, 5vw, 64px);
  --radius-s:6px;
  --radius-m:12px;
  --radius-l:20px;

  /* motion */
  --ease:cubic-bezier(.16,.84,.44,1);
  --dur-s:.25s;
  --dur-m:.6s;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; }
img{ max-width:100%; display:block; }
ul{ margin:0; padding:0; list-style:none; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,p{ margin:0; }
svg{ display:block; }

body{
  font-family:var(--f-body);
  color:var(--ink-900);
  background:var(--paper-0);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}

::selection{ background:var(--gold-500); color:var(--navy-950); }

:focus-visible{
  outline:2px solid var(--gold-500);
  outline-offset:3px;
  border-radius:2px;
}

/* ---------- Typography ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--blue-500);
  display:inline-flex;
  align-items:center;
  gap:.6em;
}
.eyebrow::before{
  content:'';
  width:18px; height:1px;
  background:var(--gold-500);
  display:inline-block;
}
.on-dark .eyebrow{ color:var(--blue-400); }

h1,.h1{
  font-family:var(--f-display);
  font-weight:600;
  letter-spacing:-.01em;
  line-height:1.04;
  font-size:clamp(2.4rem, 5.4vw, 4.6rem);
}
h2,.h2{
  font-family:var(--f-display);
  font-weight:600;
  letter-spacing:-.01em;
  line-height:1.1;
  font-size:clamp(1.9rem, 3.4vw, 2.85rem);
}
h3,.h3{
  font-family:var(--f-display);
  font-weight:600;
  line-height:1.25;
  font-size:clamp(1.15rem, 1.6vw, 1.4rem);
}
.lede{
  font-size:clamp(1.05rem, 1.6vw, 1.25rem);
  color:var(--ink-500);
  max-width:46ch;
}
.on-dark .lede{ color:#B9C4D6; }
.body-text{ color:var(--ink-500); max-width:62ch; }
.on-dark .body-text{ color:#B9C4D6; }

.mono-tag{
  font-family:var(--f-mono);
  font-size:11.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

/* ---------- Layout helpers ---------- */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding-left:var(--gutter);
  padding-right:var(--gutter);
}
section{ position:relative; }
.section-pad{ padding-block:clamp(64px, 10vw, 128px); }
.on-dark{ background:var(--navy-900); color:#fff; }
.on-paper{ background:var(--paper-50); }

.section-head{
  display:flex;
  flex-direction:column;
  gap:18px;
  margin-bottom:clamp(40px,6vw,68px);
  max-width:760px;
}
.section-head.center{ margin-inline:auto; align-items:center; text-align:center; }

/* ---------- Dimension divider (signature motif) ---------- */
.dim-divider{
  display:flex;
  align-items:center;
  gap:14px;
  color:var(--ink-300);
  margin:0 0 8px;
}
.on-dark .dim-divider{ color:#5F7494; }
.dim-divider .tick{ width:1px; height:9px; background:currentColor; }
.dim-divider .rule{ flex:1; height:1px; background:currentColor; opacity:.45; }
.dim-divider .label{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  white-space:nowrap;
}

/* ---------- Corner-bracket frame (signature motif) ---------- */
.bracket-frame{ position:relative; }
.bracket-frame::before,
.bracket-frame::after,
.bracket-frame .bk-tr,
.bracket-frame .bk-br{
  content:'';
  position:absolute;
  width:22px; height:22px;
  border:1.5px solid var(--gold-500);
  z-index:2;
  pointer-events:none;
  opacity:.9;
}
.bracket-frame::before{ top:-1px; left:-1px; border-right:none; border-bottom:none; }
.bracket-frame::after{ bottom:-1px; right:-1px; border-left:none; border-top:none; }
.bracket-frame .bk-tr{ top:-1px; right:-1px; border-left:none; border-bottom:none; }
.bracket-frame .bk-br{ bottom:-1px; left:-1px; border-right:none; border-top:none; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 26px;
  border-radius:3px;
  font-family:var(--f-body);
  font-weight:600;
  font-size:.95rem;
  border:1px solid transparent;
  transition:transform var(--dur-s) var(--ease), background var(--dur-s), border-color var(--dur-s), color var(--dur-s);
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--gold-500); color:var(--navy-950); }
.btn-primary:hover{ background:var(--gold-600); }
.btn-ghost-dark{ border-color:var(--line-dark); color:#fff; }
.btn-ghost-dark:hover{ border-color:#fff; }
.btn-ghost-light{ border-color:var(--line); color:var(--ink-900); }
.btn-ghost-light:hover{ border-color:var(--navy-900); }
.btn-arrow{ transition:transform var(--dur-s) var(--ease); }
.btn:hover .btn-arrow{ transform:translateX(3px); }
.btn-sm{ padding:10px 18px; font-size:.85rem; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:100;
  padding:18px 0;
  transition:background var(--dur-s), padding var(--dur-s), border-color var(--dur-s), backdrop-filter var(--dur-s);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(8,17,31,.86);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding:13px 0;
  border-color:var(--line-dark-soft);
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:40px; width:40px; }
.brand .word{ display:flex; flex-direction:column; line-height:1.05; }
.brand .word b{ font-family:var(--f-display); font-size:1.15rem; color:#fff; letter-spacing:-.01em; }
.brand .word span{ font-family:var(--f-mono); font-size:9.5px; letter-spacing:.12em; color:var(--blue-400); text-transform:uppercase; }

.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{
  font-size:.86rem; font-weight:500; color:#C7CFDC;
  position:relative; padding:4px 0;
  transition:color var(--dur-s);
}
.nav-links a::after{
  content:''; position:absolute; left:0; right:100%; bottom:-2px; height:1px;
  background:var(--gold-500); transition:right var(--dur-s) var(--ease);
}
.nav-links a:hover, .nav-links a.active{ color:#fff; }
.nav-links a:hover::after, .nav-links a.active::after{ right:0; }

.nav-cta{ display:flex; align-items:center; gap:18px; }
.burger{
  display:none; width:42px; height:42px; border-radius:3px;
  border:1px solid var(--line-dark); background:transparent; color:#fff;
  align-items:center; justify-content:center;
}
.burger span{ position:relative; width:18px; height:1px; background:#fff; display:block; }
.burger span::before,.burger span::after{ content:''; position:absolute; left:0; width:18px; height:1px; background:#fff; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }

.mobile-nav{
  position:fixed; inset:0; background:var(--navy-950);
  z-index:99; display:flex; flex-direction:column;
  padding:100px var(--gutter) 40px;
  transform:translateY(-100%); transition:transform .4s var(--ease);
}
.mobile-nav.open{ transform:translateY(0); }
.mobile-nav a{ font-family:var(--f-display); font-size:1.6rem; color:#fff; padding:14px 0; border-bottom:1px solid var(--line-dark-soft); }
.mobile-nav .btn{ margin-top:30px; align-self:flex-start; }

/* ---------- Sheet index badge (signature element) ---------- */
.sheet-index{
  position:fixed; left:18px; bottom:18px; z-index:90;
  display:flex; align-items:center; gap:10px;
  background:rgba(8,17,31,.88);
  border:1px solid var(--line-dark);
  backdrop-filter:blur(10px);
  border-radius:3px;
  padding:9px 14px;
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.06em; color:#9FB0C8;
  opacity:0; transform:translateY(8px);
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.sheet-index.show{ opacity:1; transform:translateY(0); }
.sheet-index b{ color:#fff; }
.sheet-index .bar{ width:54px; height:3px; background:var(--line-dark); position:relative; border-radius:2px; overflow:hidden; }
.sheet-index .bar i{ position:absolute; left:0; top:0; bottom:0; width:0%; background:var(--gold-500); transition:width .25s linear; }
.sheet-index button{ background:none; border:none; color:#9FB0C8; display:flex; }
.sheet-index button:hover{ color:#fff; }

@media (max-width:720px){ .sheet-index{ display:none; } }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-end;
  color:#fff;
  overflow:hidden;
  background:var(--navy-950);
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.04); }
.hero-media::after{
  content:'';
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,14,26,.55) 0%, rgba(8,14,26,.45) 35%, rgba(7,13,24,.92) 86%, #07101D 100%),
    linear-gradient(90deg, rgba(7,13,24,.55) 0%, transparent 38%, transparent 62%, rgba(7,13,24,.55) 100%);
}
.hero-viewport{
  position:absolute; inset:clamp(14px,3vw,34px);
  border:1px solid rgba(255,255,255,.16);
  pointer-events:none; z-index:1;
}
.hero-viewport .c-tl,.hero-viewport .c-tr,.hero-viewport .c-bl,.hero-viewport .c-br{ position:absolute; width:26px; height:26px; border:1.5px solid var(--gold-500); }
.hero-viewport .c-tl{ top:-1.5px; left:-1.5px; border-right:none; border-bottom:none; }
.hero-viewport .c-tr{ top:-1.5px; right:-1.5px; border-left:none; border-bottom:none; }
.hero-viewport .c-bl{ bottom:-1.5px; left:-1.5px; border-right:none; border-top:none; }
.hero-viewport .c-br{ bottom:-1.5px; right:-1.5px; border-left:none; border-top:none; }

.hero-content{ position:relative; z-index:2; width:100%; padding-bottom:clamp(40px,7vw,80px); padding-top:160px; }
.hero-eyebrow{
  font-family:var(--f-mono); font-size:12.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--blue-400); display:flex; align-items:center; gap:10px; margin-bottom:22px;
}
.hero-eyebrow .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold-500); }
.hero h1{ max-width:880px; }
.hero h1 em{ font-style:normal; color:var(--gold-500); }
.hero-sub{ margin-top:22px; max-width:540px; font-size:1.1rem; color:#C2CCDC; }
.hero-actions{ display:flex; gap:16px; margin-top:38px; flex-wrap:wrap; }

.hero-status{
  position:relative; z-index:2;
  border-top:1px solid var(--line-dark);
  margin-top:clamp(40px,6vw,70px);
}
.hero-status .wrap{
  display:flex; flex-wrap:wrap; gap:0;
  padding-top:20px;
}
.hero-status .stat{
  flex:1; min-width:200px;
  padding:0 26px 4px 0;
  border-right:1px solid var(--line-dark-soft);
}
.hero-status .stat:last-child{ border-right:none; }
.hero-status .stat .mono-tag{ color:var(--gold-500); display:block; margin-bottom:6px; }
.hero-status .stat p{ color:#C2CCDC; font-size:.92rem; }

.scroll-cue{
  position:absolute; right:var(--gutter); bottom:28px; z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:#C2CCDC; font-family:var(--f-mono); font-size:10px; letter-spacing:.1em;
}
.scroll-cue .line{ width:1px; height:34px; background:linear-gradient(#fff,transparent); animation:scrollcue 1.8s infinite var(--ease); }
@keyframes scrollcue{ 0%{transform:scaleY(0); transform-origin:top;} 50%{transform:scaleY(1); transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0); transform-origin:bottom;} }

@media (max-width:720px){
  .hero-content{ padding-top:130px; }
  .hero-status .stat{ min-width:140px; flex-basis:45%; }
  .scroll-cue{ display:none; }
}

/* ---------- Reveal animation ---------- */
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.js .reveal.in{ opacity:1; transform:translateY(0); }
.reveal-stagger > *{ transition-delay:calc(var(--i,0) * 80ms); }

/* ---------- About section ---------- */
.about-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(40px,6vw,90px); align-items:start; }
.about-copy p + p{ margin-top:16px; }
.about-list{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.about-list li{ display:flex; gap:14px; align-items:flex-start; font-size:.98rem; color:var(--ink-700); }
.about-list .ico{ flex:none; width:22px; height:22px; color:var(--green-600); margin-top:1px; }

.approach-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); }
.approach-card{ background:#fff; padding:26px 22px; }
.approach-card .ico{ width:26px; height:26px; color:var(--blue-500); margin-bottom:14px; }
.approach-card h4{ font-family:var(--f-display); font-size:1.02rem; margin-bottom:8px; }
.approach-card p{ font-size:.88rem; color:var(--ink-500); }

.industries-strip{ margin-top:clamp(50px,6vw,80px); border-top:1px solid var(--line); padding-top:34px; }
.industries-strip .label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-300); margin-bottom:20px; display:block; }
.pill-row{ display:flex; gap:14px; flex-wrap:wrap; }
.pill{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--line); border-radius:40px; padding:10px 20px 10px 14px;
  font-size:.88rem; font-weight:600; color:var(--ink-700);
  transition:border-color var(--dur-s), background var(--dur-s);
}
.pill:hover{ border-color:var(--blue-500); background:var(--paper-50); }
.pill .ico{ width:18px; height:18px; color:var(--blue-500); }

@media (max-width:880px){
  .about-grid{ grid-template-columns:1fr; }
  .approach-grid{ grid-template-columns:1fr 1fr; }
}

/* ---------- Capability cards (Manufacturing Solutions) ---------- */
.cap-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.cap-card{
  position:relative; border-radius:var(--radius-m); overflow:hidden;
  background:var(--navy-900); color:#fff;
  display:flex; flex-direction:column;
}
.cap-card .img-box{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.cap-card .img-box img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.cap-card:hover .img-box img{ transform:scale(1.08); }
.cap-card .img-box::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(8,15,28,.88) 100%); }
.cap-card .num{ position:absolute; top:14px; left:14px; font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; color:var(--gold-500); z-index:2; }
.cap-card .body{ padding:20px 22px 26px; flex:1; display:flex; flex-direction:column; gap:10px; }
.cap-card h3{ color:#fff; }
.cap-card p{ font-size:.88rem; color:#A9B5C9; }
.cap-card .ico{ width:30px; height:30px; color:var(--blue-400); margin-bottom:4px; }

.tag-row{ margin-top:48px; display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  border:1px solid var(--line); border-radius:3px; padding:8px 13px; color:var(--ink-500);
}

@media (max-width:980px){ .cap-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .cap-grid{ grid-template-columns:1fr; } }

/* ---------- Lifecycle timeline ---------- */
.lifecycle-layout{ display:grid; grid-template-columns:1.55fr .9fr; gap:clamp(40px,6vw,80px); align-items:start; }
.timeline{ position:relative; }
.timeline::before{ content:''; position:absolute; left:23px; top:8px; bottom:8px; width:1px; background:var(--line-dark); }
.t-step{ position:relative; display:grid; grid-template-columns:48px 1fr; gap:22px; padding-bottom:34px; }
.t-step:last-child{ padding-bottom:0; }
.t-step .marker{
  position:relative; z-index:1;
  width:48px; height:48px; border-radius:50%;
  background:var(--navy-800); border:1px solid var(--line-dark);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-mono); font-weight:600; color:var(--gold-500); font-size:.95rem;
  transition:background var(--dur-s), border-color var(--dur-s);
}
.t-step.in .marker{ background:var(--gold-500); border-color:var(--gold-500); color:var(--navy-950); }
.t-step .content h4{ color:#fff; font-family:var(--f-display); font-size:1.08rem; margin-bottom:6px; display:flex; align-items:center; gap:10px; }
.t-step .content p{ color:#A9B5C9; font-size:.92rem; max-width:46ch; }
.t-step .phase{ font-family:var(--f-mono); font-size:10px; color:#5F7494; letter-spacing:.08em; text-transform:uppercase; margin-top:8px; display:block; }

.types-stack{ display:flex; flex-direction:column; gap:18px; position:sticky; top:120px; }
.type-card{
  border-radius:var(--radius-m); overflow:hidden; position:relative;
  border:1px solid var(--line-dark);
}
.type-card .img-box{ aspect-ratio:16/9; overflow:hidden; }
.type-card img{ width:100%; height:100%; object-fit:cover; }
.type-card .cap{ padding:16px 18px; background:var(--navy-800); }
.type-card .cap b{ font-family:var(--f-display); color:#fff; font-size:1rem; display:block; margin-bottom:4px; }
.type-card .cap span{ font-size:.82rem; color:#A9B5C9; }

@media (max-width:980px){
  .lifecycle-layout{ grid-template-columns:1fr; }
  .types-stack{ position:static; flex-direction:row; overflow-x:auto; padding-bottom:6px; }
  .type-card{ min-width:240px; }
}

/* ---------- Services section ---------- */
.services-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,70px); }
.service-block .head{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.service-block .head .ico{ width:30px; height:30px; color:var(--blue-500); }
.service-block .head h3{ color:var(--ink-900); }
.service-block ul{ display:flex; flex-direction:column; gap:13px; }
.service-block li{ display:flex; gap:12px; font-size:.96rem; color:var(--ink-700); }
.service-block li .ico{ width:18px; height:18px; color:var(--green-600); flex:none; margin-top:3px; }

.utility-grid{ margin-top:60px; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.utility-card{
  background:var(--navy-800); border:1px solid var(--line-dark); border-radius:var(--radius-m);
  padding:24px; display:flex; flex-direction:column; gap:12px; color:#fff;
}
.utility-card .ico{ width:28px; height:28px; color:var(--gold-500); }
.utility-card h4{ font-family:var(--f-display); font-size:1rem; }
.utility-card p{ font-size:.85rem; color:#A9B5C9; }

.equipment-callout{
  margin-top:40px; border:1px solid var(--line-dark); border-radius:var(--radius-m);
  padding:28px 30px; display:flex; gap:22px; align-items:center; background:var(--navy-800);
}
.equipment-callout .ico{ width:40px; height:40px; color:var(--gold-500); flex:none; }
.equipment-callout p{ color:#C2CCDC; font-size:.95rem; }
.equipment-callout strong{ color:#fff; }

@media (max-width:980px){
  .services-grid{ grid-template-columns:1fr; }
  .utility-grid{ grid-template-columns:1fr 1fr; }
  .equipment-callout{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:560px){ .utility-grid{ grid-template-columns:1fr; } }

/* ---------- Equipment & Delivery section ---------- */
.equip-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.equip-card{ border-radius:var(--radius-m); overflow:hidden; border:1px solid var(--line); background:#fff; }
.equip-card .img-box{ aspect-ratio:1/1; overflow:hidden; }
.equip-card .img-box img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.equip-card:hover .img-box img{ transform:scale(1.06); }
.equip-card .label{ padding:14px 16px; font-family:var(--f-display); font-size:.92rem; }

.split-2col{ margin-top:64px; display:grid; grid-template-columns:1fr 1fr; gap:60px; }
.checklist{ display:flex; flex-direction:column; gap:13px; }
.checklist li{ display:flex; gap:12px; font-size:.96rem; color:var(--ink-700); }
.checklist .ico{ width:18px; height:18px; color:var(--green-600); flex:none; margin-top:3px; }

.strength-row{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.strength{ text-align:center; padding:18px 8px; border:1px solid var(--line); border-radius:var(--radius-s); }
.strength .ico{ width:26px; height:26px; color:var(--blue-500); margin:0 auto 12px; }
.strength span{ font-size:.78rem; font-weight:600; color:var(--ink-700); }

.pull-quote{
  margin-top:60px; border-left:2px solid var(--gold-500);
  padding-left:28px; font-family:var(--f-display); font-size:clamp(1.25rem,2.4vw,1.65rem);
  color:var(--ink-900); max-width:62ch;
}

@media (max-width:980px){
  .equip-grid{ grid-template-columns:repeat(2,1fr); }
  .split-2col{ grid-template-columns:1fr; gap:40px; }
  .strength-row{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:560px){ .strength-row{ grid-template-columns:repeat(2,1fr); } }

/* ---------- Why HavenCore ---------- */
.reasons-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.reason-card{ background:#fff; padding:32px 28px; }
.reason-card .ico{ width:30px; height:30px; color:var(--gold-600); margin-bottom:18px; }
.reason-card h3{ margin-bottom:10px; }
.reason-card p{ color:var(--ink-500); font-size:.92rem; }

.deliverables{ margin-top:64px; }
.deliverables .label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-300); margin-bottom:22px; display:block; }
.deliverables-row{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.deliv-chip{ border:1px solid var(--line); border-radius:var(--radius-s); padding:18px 14px; text-align:center; }
.deliv-chip .ico{ width:24px; height:24px; color:var(--blue-500); margin:0 auto 10px; }
.deliv-chip span{ font-size:.78rem; font-weight:600; color:var(--ink-700); line-height:1.3; }

.brand-quote{
  margin-top:70px; text-align:center; padding:50px var(--gutter);
  background:var(--navy-900); border-radius:var(--radius-l); color:#fff;
}
.brand-quote svg{ width:34px; height:34px; color:var(--gold-500); margin:0 auto 22px; }
.brand-quote p{ font-family:var(--f-display); font-size:clamp(1.2rem,2.6vw,1.7rem); max-width:46ch; margin:0 auto; line-height:1.4; }

@media (max-width:980px){
  .reasons-grid{ grid-template-columns:1fr 1fr; }
  .deliverables-row{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:640px){
  .reasons-grid{ grid-template-columns:1fr; }
  .deliverables-row{ grid-template-columns:repeat(2,1fr); }
}

/* ---------- Gallery ---------- */
.gallery-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); grid-auto-rows:170px; gap:10px;
}
.gallery-item{ position:relative; overflow:hidden; border-radius:var(--radius-s); cursor:zoom-in; background:var(--navy-900); }
.gallery-item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.gallery-item:hover img{ transform:scale(1.07); }
.gallery-item .cap{
  position:absolute; left:0; right:0; bottom:0; padding:12px 14px 10px;
  background:linear-gradient(180deg, transparent, rgba(6,11,20,.92));
  color:#fff; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.05em; text-transform:uppercase;
  opacity:0; transform:translateY(6px); transition:opacity var(--dur-s), transform var(--dur-s);
}
.gallery-item:hover .cap{ opacity:1; transform:translateY(0); }
.gallery-item.tall{ grid-row:span 2; }
.gallery-item.wide{ grid-column:span 2; }

@media (max-width:900px){
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gallery-item.wide{ grid-column:span 2; }
}
@media (max-width:560px){
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:120px; }
  .gallery-item.tall{ grid-row:span 1; }
  .gallery-item.wide{ grid-column:span 1; }
}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(6,10,18,.94);
  display:flex; align-items:center; justify-content:center; padding:6vh 5vw;
  opacity:0; visibility:hidden; transition:opacity .3s var(--ease);
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:100%; max-height:84vh; border-radius:4px; }
.lightbox .lb-cap{ position:absolute; bottom:6vh; left:0; right:0; text-align:center; color:#C2CCDC; font-family:var(--f-mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; }
.lightbox .lb-close{ position:absolute; top:24px; right:28px; width:44px; height:44px; border:1px solid var(--line-dark); border-radius:50%; background:transparent; color:#fff; display:flex; align-items:center; justify-content:center; }
.lightbox .lb-close:hover{ background:rgba(255,255,255,.08); }

/* ---------- Contact ---------- */
.contact-layout{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,6vw,90px); }
.contact-cards{ display:flex; flex-direction:column; gap:16px; }
.contact-card{
  display:flex; gap:16px; align-items:flex-start; padding:22px;
  border:1px solid var(--line-dark); border-radius:var(--radius-m); background:var(--navy-800);
}
.contact-card .ico{ width:24px; height:24px; color:var(--gold-500); flex:none; margin-top:2px; }
.contact-card b{ display:block; color:#fff; font-family:var(--f-display); margin-bottom:4px; }
.contact-card span,.contact-card a{ color:#A9B5C9; font-size:.92rem; }
.contact-card a:hover{ color:#fff; }

.form-card{
  background:var(--navy-800); border:1px solid var(--line-dark); border-radius:var(--radius-l);
  padding:clamp(26px,4vw,40px);
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column:1/-1; }
.field label{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:#8FA0BC; }
.field input,.field select,.field textarea{
  background:var(--navy-900); border:1px solid var(--line-dark); border-radius:4px;
  padding:13px 14px; color:#fff; font-family:var(--f-body); font-size:.94rem; resize:vertical;
}
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--blue-500); outline:none; }
.field input::placeholder,.field textarea::placeholder{ color:#56668A; }
.form-note{ font-size:.78rem; color:#7587A6; margin-top:14px; }
.form-success{ display:none; margin-top:16px; padding:14px 16px; border:1px solid var(--green-600); border-radius:4px; color:#9fe3ad; font-size:.88rem; background:rgba(72,174,99,.08); }
.form-success.show{ display:block; }

@media (max-width:980px){
  .contact-layout{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .form-row{ grid-template-columns:1fr; }
}

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-950); color:#fff; padding-top:70px; }
.footer-top{ display:grid; grid-template-columns:1.3fr .7fr .7fr .9fr; gap:50px; padding-bottom:50px; border-bottom:1px solid var(--line-dark-soft); }
.footer-brand .brand{ margin-bottom:18px; }
.footer-brand p{ color:#90A0BC; font-size:.9rem; max-width:34ch; }
.footer-col .ftitle{ font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:#5F7494; margin-bottom:18px; display:block; }
.footer-col a,.footer-col span{ display:block; font-size:.9rem; color:#B9C4D6; margin-bottom:11px; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding:24px 0; flex-wrap:wrap; gap:12px; }
.footer-bottom span{ font-family:var(--f-mono); font-size:11px; color:#5F7494; letter-spacing:.04em; }

@media (max-width:900px){
  .footer-top{ grid-template-columns:1fr 1fr; row-gap:36px; }
}
@media (max-width:560px){
  .footer-top{ grid-template-columns:1fr; }
}

/* ---------- misc ---------- */
.hidden-mobile{ }
@media (max-width:880px){
  .nav-links{ display:none; }
  .nav-cta .btn{ display:none; }
  .burger{ display:flex; }
}

/* ---------- Build additions: media frames, gallery packing, a11y ---------- */
.skip-link{
  position:absolute; left:12px; top:-60px; z-index:300;
  background:var(--gold-500); color:var(--navy-950); font-weight:600;
  padding:10px 16px; border-radius:3px; font-size:.85rem;
  transition:top .25s var(--ease);
}
.skip-link:focus{ top:12px; }

.media-fill{ position:relative; height:100%; border-radius:inherit; overflow:hidden; }
.media-fill img{ width:100%; height:100%; object-fit:cover; display:block; }
.about-media{ position:relative; aspect-ratio:4/5; border-radius:var(--radius-l); }
.split-media{ position:relative; aspect-ratio:4/3; border-radius:var(--radius-l); }
.type-card .img-box.media-fill{ border-radius:0; }

.gallery-grid{ grid-auto-flow:dense; }

@media (max-width:720px){
  .about-media{ aspect-ratio:16/10; }
}
