/* ============================================================
   ALAMIYAH MARINE — Design System
   Premium maritime authority. Fraunces + Inter + IBM Plex Mono.
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  /* Color */
  --abyss:      #0A1A2F;   /* base dark */
  --abyss-900:  #06121F;   /* deepest */
  --abyss-800:  #0E2236;
  --abyss-700:  #16314A;
  --steel:      #2B4A66;
  --slate:      #5C7488;
  --mist:       #9FB1BF;
  --fog:        #C9D4DC;
  --paper:      #F6F4EF;   /* warm off-white */
  --paper-2:    #EDE9E1;
  --white:      #FFFFFF;
  --brass:      #C2A063;
  --brass-deep: #A4823F;
  --brass-soft: #E7D8B7;
  --ink:        #11202E;

  /* Type */
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, sans-serif;
  --mono:  "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Fluid type scale */
  --fs-eyebrow: clamp(0.72rem, 0.68rem + 0.2vw, 0.8rem);
  --fs-body:    clamp(1rem, 0.96rem + 0.25vw, 1.08rem);
  --fs-lead:    clamp(1.15rem, 1.05rem + 0.6vw, 1.4rem);
  --fs-h4:      clamp(1.1rem, 1rem + 0.5vw, 1.35rem);
  --fs-h3:      clamp(1.5rem, 1.25rem + 1.2vw, 2.1rem);
  --fs-h2:      clamp(2rem, 1.5rem + 2.6vw, 3.4rem);
  --fs-h1:      clamp(2.6rem, 1.7rem + 4.6vw, 5.6rem);
  --fs-mega:    clamp(3rem, 1.4rem + 7vw, 8rem);

  /* Spacing */
  --gut: clamp(1.25rem, 4vw, 4rem);
  --sp-section: clamp(4.5rem, 9vw, 9rem);
  --maxw: 1240px;
  --maxw-text: 64ch;

  --radius: 4px;
  --radius-lg: 10px;
  --shadow: 0 24px 60px -28px rgba(6,18,31,.5);
  --shadow-soft: 0 18px 50px -30px rgba(6,18,31,.35);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
:focus-visible { outline: 2px solid var(--brass); outline-offset: 3px; }

/* ---------- Layout ---------- */
.wrap { width: min(var(--maxw), 100% - var(--gut) * 2); margin-inline: auto; }
.wrap-wide { width: min(1400px, 100% - var(--gut) * 2); margin-inline: auto; }
section { position: relative; }
.section { padding-block: var(--sp-section); }
.lede { max-width: var(--maxw-text); }

/* ---------- Typography helpers ---------- */
.eyebrow {
  font-family: var(--mono);
  font-size: var(--fs-eyebrow);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--brass-deep);
  display: inline-flex; align-items: center; gap: .7em;
  font-weight: 500;
}
.eyebrow::before {
  content: ""; width: 28px; height: 1px; background: var(--brass);
  display: inline-block;
}
.eyebrow.center::before { display: none; }
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 380; line-height: 1.04; letter-spacing: -0.015em; font-optical-sizing: auto; }
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); line-height: 1.2; }
.serif-italic { font-style: italic; }
.display { font-family: var(--serif); }
.mono { font-family: var(--mono); }
strong { font-weight: 600; }
.muted { color: var(--slate); }
.balance { text-wrap: balance; }
.pretty { text-wrap: pretty; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--mono); font-size: .82rem; letter-spacing: .08em;
  text-transform: uppercase; font-weight: 500;
  padding: 1.05em 1.7em; border-radius: var(--radius);
  transition: all .35s var(--ease); position: relative;
}
.btn .arrow { transition: transform .35s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }
.btn-primary { background: var(--brass); color: var(--abyss-900); }
.btn-primary:hover { background: var(--brass-soft); }
.btn-ghost { color: var(--white); box-shadow: inset 0 0 0 1px rgba(255,255,255,.32); }
.btn-ghost:hover { box-shadow: inset 0 0 0 1px var(--brass); color: var(--brass-soft); }
.btn-dark { background: var(--abyss); color: var(--white); }
.btn-dark:hover { background: var(--abyss-700); }
.link-arrow {
  font-family: var(--mono); font-size: .8rem; letter-spacing: .08em;
  text-transform: uppercase; color: var(--brass-deep); font-weight: 500;
  display: inline-flex; align-items: center; gap: .5em;
  border-bottom: 1px solid transparent; padding-bottom: 2px;
  transition: border-color .3s var(--ease);
}
.link-arrow:hover { border-color: var(--brass); }
.link-arrow .arrow { transition: transform .3s var(--ease); }
.link-arrow:hover .arrow { transform: translateX(4px); }

/* ---------- Header ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  padding-block: 1.1rem; transition: background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.scrolled {
  background: rgba(8,18,31,.86); backdrop-filter: blur(14px) saturate(140%);
  padding-block: .7rem; box-shadow: 0 1px 0 rgba(255,255,255,.06);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.brand { display: flex; align-items: center; gap: .8rem; color: var(--white); }
.brand-mark {
  width: 38px; height: 38px; flex-shrink: 0; border-radius: 50%;
  display: grid; place-items: center;
  background: radial-gradient(circle at 30% 28%, var(--brass-soft), var(--brass) 60%, var(--brass-deep));
  color: var(--abyss-900); font-family: var(--serif); font-weight: 600; font-size: 1.15rem;
  box-shadow: 0 0 0 1px rgba(255,255,255,.12), inset 0 -2px 6px rgba(0,0,0,.18);
}
.brand-name { font-family: var(--serif); font-size: 1.18rem; line-height: 1; letter-spacing: -.01em; }
.brand-name span { display: block; font-family: var(--mono); font-size: .56rem; letter-spacing: .34em; color: var(--brass-soft); margin-top: 4px; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: 2rem; }
.nav-links a {
  color: rgba(255,255,255,.82); font-size: .92rem; letter-spacing: .01em;
  position: relative; padding-block: .3rem; transition: color .3s;
}
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; height: 1px; width: 0;
  background: var(--brass); transition: width .3s var(--ease);
}
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--white); }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { width: 100%; }
.nav-cta { display: flex; align-items: center; gap: 1.2rem; }
.nav-toggle { display: none; width: 30px; height: 22px; position: relative; z-index: 110; }
.nav-toggle span { position: absolute; left: 0; width: 100%; height: 2px; background: var(--white); transition: .35s var(--ease); }
.nav-toggle span:nth-child(1){ top: 0; }
.nav-toggle span:nth-child(2){ top: 10px; }
.nav-toggle span:nth-child(3){ top: 20px; }
body.menu-open .nav-toggle span:nth-child(1){ top: 10px; transform: rotate(45deg); }
body.menu-open .nav-toggle span:nth-child(2){ opacity: 0; }
body.menu-open .nav-toggle span:nth-child(3){ top: 10px; transform: rotate(-45deg); }

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: flex-end;
  color: var(--white); overflow: hidden; background: var(--abyss-900);
}
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; opacity: .82; }
.hero-media::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(6,18,31,.62) 0%, rgba(6,18,31,.2) 32%, rgba(6,18,31,.78) 82%, var(--abyss-900) 100%),
    linear-gradient(95deg, rgba(6,18,31,.7) 0%, rgba(6,18,31,0) 60%);
}
.hero-inner { position: relative; z-index: 2; padding-block: clamp(7rem, 14vh, 11rem) clamp(3.5rem, 8vh, 6rem); width: 100%; }
.hero h1 { max-width: 16ch; margin-top: 1.3rem; }
.hero h1 em { font-style: italic; color: var(--brass-soft); }
.hero-lede { max-width: 50ch; margin-top: 1.6rem; color: rgba(255,255,255,.84); font-size: var(--fs-lead); font-weight: 300; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.4rem; }
.hero-scroll {
  position: absolute; right: var(--gut); bottom: 2.2rem; z-index: 3;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .25em; text-transform: uppercase;
  color: rgba(255,255,255,.6); display: flex; align-items: center; gap: .8rem;
  writing-mode: vertical-rl;
}
.hero-scroll .line { width: 1px; height: 54px; background: linear-gradient(var(--brass), transparent); animation: scrolldown 2.4s var(--ease) infinite; }
@keyframes scrolldown { 0%{transform:scaleY(.2);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform-origin:bottom} 100%{transform:scaleY(.2);transform-origin:bottom} }

/* ---------- Stat strip ---------- */
.stripe { background: var(--abyss-900); color: var(--white); }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: clamp(2rem, 4vw, 3rem) clamp(1.2rem, 2.5vw, 2.4rem); border-right: 1px solid rgba(255,255,255,.08); }
.stat:last-child { border-right: 0; }
.stat .num { font-family: var(--serif); font-size: clamp(2.4rem, 1.5rem + 3vw, 4rem); line-height: 1; color: var(--brass-soft); }
.stat .num small { font-size: .5em; color: var(--brass); }
.stat .lbl { font-family: var(--mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--mist); margin-top: .9rem; }

/* ---------- Client / trust row ---------- */
.trust { background: var(--abyss-800); color: var(--mist); padding-block: 2.2rem; border-top: 1px solid rgba(255,255,255,.06); }
.trust-inner { display: flex; align-items: center; gap: clamp(1.5rem,4vw,3.5rem); flex-wrap: wrap; justify-content: center; }
.trust-label { font-family: var(--mono); font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--slate); }
.trust-logos { display: flex; flex-wrap: wrap; gap: clamp(1.4rem,3.5vw,3rem); align-items: center; justify-content: center; }
.trust-logos span { font-family: var(--serif); font-size: clamp(1.05rem,2vw,1.45rem); letter-spacing: .02em; color: rgba(255,255,255,.7); white-space: nowrap; }

/* ---------- Generic dark/light section ---------- */
.dark { background: var(--abyss); color: var(--white); }
.dark .muted { color: var(--mist); }
.dark .eyebrow { color: var(--brass-soft); }
.dark .eyebrow::before { background: var(--brass); }
.deepdark { background: var(--abyss-900); color: var(--white); }
.section-head { max-width: 60ch; }
.section-head h2 { margin-top: 1.1rem; }
.section-head p { margin-top: 1.3rem; font-size: var(--fs-lead); font-weight: 300; }

/* ---------- Split (image + text) ---------- */
.split { display: grid; grid-template-columns: 1.05fr 1fr; align-items: center; gap: clamp(2rem, 5vw, 5rem); }
.split.flip { direction: rtl; } .split.flip > * { direction: ltr; }
.split-media { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 4/3; }
.split-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease); }
.split-media:hover img { transform: scale(1.05); }
.split-tag {
  position: absolute; left: 1rem; bottom: 1rem; z-index: 2;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  background: rgba(8,18,31,.72); backdrop-filter: blur(6px); color: var(--brass-soft);
  padding: .55em 1em; border-radius: var(--radius); border: 1px solid rgba(255,255,255,.12);
}

/* ---------- Services grid ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); overflow: hidden; }
.svc { background: var(--abyss); padding: clamp(1.8rem, 3vw, 2.8rem); transition: background .4s var(--ease); position: relative; }
.svc:hover { background: var(--abyss-700); }
.svc .idx { font-family: var(--mono); font-size: .78rem; color: var(--brass); letter-spacing: .1em; }
.svc h4 { margin-top: 1.1rem; color: var(--white); }
.svc p { margin-top: .8rem; color: var(--mist); font-size: .98rem; }
.svc .link-arrow { margin-top: 1.4rem; color: var(--brass-soft); }
.svc .link-arrow:hover { border-color: var(--brass); }

/* ---------- Vessel capability grid ---------- */
.fleet-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1px; background: var(--paper-2); border: 1px solid var(--paper-2); }
.fleet-cell { background: var(--paper); padding: 1.6rem 1.4rem; transition: background .3s; }
.fleet-cell:hover { background: var(--white); }
.fleet-cell .code { font-family: var(--mono); font-size: .7rem; letter-spacing: .12em; color: var(--brass-deep); }
.fleet-cell .name { margin-top: .5rem; font-weight: 600; font-size: 1rem; color: var(--ink); }
.fleet-cell .desc { margin-top: .3rem; font-size: .85rem; color: var(--slate); }

/* ---------- Value cards ---------- */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.4rem; }
.card { background: var(--white); border: 1px solid var(--paper-2); border-radius: var(--radius-lg); padding: clamp(1.6rem, 2.4vw, 2.2rem); transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); }
.card .ic { width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; background: var(--paper); color: var(--brass-deep); margin-bottom: 1.2rem; }
.card h4 { color: var(--ink); }
.card p { margin-top: .7rem; color: var(--slate); font-size: .96rem; }

/* ---------- VMV blocks ---------- */
.vmv { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,.1); border-radius: var(--radius-lg); overflow: hidden; }
.vmv > div { background: var(--abyss); padding: clamp(2rem,3vw,2.8rem); }
.vmv .k { font-family: var(--mono); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--brass); }
.vmv h3 { margin: 1rem 0; color: var(--white); }
.vmv p { color: var(--mist); font-size: .98rem; }

/* ---------- Leadership ---------- */
.leaders { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.4rem; }
.leader { background: var(--white); border: 1px solid var(--paper-2); border-radius: var(--radius-lg); padding: clamp(1.6rem,2.4vw,2.2rem); display: flex; flex-direction: column; }
.leader-top { display: flex; gap: 1.1rem; align-items: center; }
.monogram { width: 60px; height: 60px; flex-shrink: 0; border-radius: 50%; display: grid; place-items: center; font-family: var(--serif); font-size: 1.4rem; color: var(--abyss-900); background: radial-gradient(circle at 32% 28%, var(--brass-soft), var(--brass) 65%, var(--brass-deep)); box-shadow: inset 0 -3px 8px rgba(0,0,0,.16); }
.leader .nm { font-family: var(--serif); font-size: 1.22rem; color: var(--ink); line-height: 1.1; }
.leader .ro { font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--brass-deep); margin-top: .45rem; }
.leader .bio { margin-top: 1.3rem; font-size: .92rem; color: var(--slate); line-height: 1.6; }
.leader .tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1.2rem; }
.leader .tags span { font-family: var(--mono); font-size: .62rem; letter-spacing: .06em; text-transform: uppercase; color: var(--steel); background: var(--paper); border: 1px solid var(--paper-2); padding: .35em .7em; border-radius: 100px; }

/* ---------- Org chart ---------- */
.org { display: grid; gap: 1px; background: rgba(255,255,255,.1); border-radius: var(--radius-lg); overflow: hidden; }
.org-tier { background: var(--abyss); padding: 1.4rem clamp(1.4rem,2.5vw,2.2rem); display: flex; flex-wrap: wrap; align-items: baseline; gap: .6rem 1.4rem; }
.org-tier .role { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--brass); min-width: 200px; }
.org-tier .people { color: var(--fog); font-size: .98rem; }
.org-tier .people b { color: var(--white); font-weight: 500; }

/* ---------- Track record ---------- */
.filterbar { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 2.5rem; }
.chip { font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; padding: .6em 1.1em; border-radius: 100px; color: var(--slate); box-shadow: inset 0 0 0 1px var(--paper-2); transition: all .3s var(--ease); }
.chip:hover { color: var(--ink); }
.chip[aria-pressed="true"] { background: var(--abyss); color: var(--white); box-shadow: inset 0 0 0 1px var(--abyss); }
.timeline { border-top: 1px solid var(--paper-2); }
.trow { display: grid; grid-template-columns: 110px 1.4fr 1fr 1fr; gap: 1.5rem; align-items: baseline; padding: 1.5rem 0; border-bottom: 1px solid var(--paper-2); transition: opacity .4s, background .3s; }
.trow:hover { background: rgba(0,0,0,.015); }
.trow .yr { font-family: var(--mono); font-weight: 600; color: var(--brass-deep); font-size: 1.05rem; }
.trow .client { font-family: var(--serif); font-size: 1.18rem; color: var(--ink); }
.trow .scope { color: var(--slate); font-size: .95rem; }
.trow .vessel { font-family: var(--mono); font-size: .8rem; letter-spacing: .03em; color: var(--steel); text-transform: uppercase; }
.trow .vessel .loc { display: block; color: var(--slate); margin-top: .3rem; text-transform: none; letter-spacing: 0; font-family: var(--sans); font-size: .85rem; }
.trow[hidden] { display: none; }

/* ---------- Fleet & Operations table ---------- */
.fleet-legend { display: flex; flex-wrap: wrap; gap: .8rem 1.5rem; margin-top: 1.6rem; }
.fleet-legend span { font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--slate); display: inline-flex; align-items: center; gap: .55em; }
.fleet-legend i { width: 12px; height: 12px; border-radius: 3px; display: inline-block; }
.lg-managed { background: var(--brass); }
.lg-operated { box-shadow: inset 0 0 0 1.5px var(--steel); }
.lg-planned { box-shadow: inset 0 0 0 1.5px var(--brass-deep); background: repeating-linear-gradient(45deg, transparent, transparent 3px, rgba(164,130,63,.4) 3px, rgba(164,130,63,.4) 5px); }

.ftable { margin-top: 2.5rem; border-top: 2px solid var(--ink); }
.fhead, .frow { display: grid; grid-template-columns: 1.5fr 1fr 1.6fr 170px; gap: 1.5rem; align-items: center; }
.fhead { padding: 1rem 0; border-bottom: 1px solid var(--paper-2); }
.fhead span { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); }
.frow { padding: 1.35rem 0; border-bottom: 1px solid var(--paper-2); transition: background .3s; }
.frow:hover { background: rgba(0,0,0,.015); }
.frow .fv { font-family: var(--serif); font-size: 1.2rem; color: var(--ink); line-height: 1.15; }
.frow .ft { font-family: var(--mono); font-size: .78rem; letter-spacing: .03em; text-transform: uppercase; color: var(--steel); }
.frow .fc { color: var(--slate); font-size: .95rem; }
.fstat { justify-self: start; font-family: var(--mono); font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; padding: .5em 1em; border-radius: 100px; white-space: nowrap; font-weight: 500; }
.fstat--managed { background: var(--brass); color: var(--abyss-900); }
.fstat--operated { color: var(--steel); box-shadow: inset 0 0 0 1px var(--paper-2); }
.fstat--planned { color: var(--brass-deep); box-shadow: inset 0 0 0 1px var(--brass-deep); border-style: dashed; }
.fnote { margin-top: 1.6rem; font-size: .88rem; color: var(--slate); max-width: 64ch; }

@media (max-width: 760px) {
  .fhead { display: none; }
  .frow { grid-template-columns: 1fr auto; gap: .5rem 1rem; padding: 1.5rem 0; }
  .frow .fv { grid-column: 1; }
  .frow .fstat { grid-column: 2; grid-row: 1; align-self: start; }
  .frow .ft { grid-column: 1 / -1; }
  .frow .fc { grid-column: 1 / -1; }
}

/* ---------- Hero credibility chips ---------- */
.hero-chips { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.9rem; }
.hero-chips span { font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--brass-soft); border: 1px solid rgba(194,160,99,.4); padding: .55em 1em; border-radius: 100px; background: rgba(8,18,31,.28); backdrop-filter: blur(4px); }

/* ---------- Capability snapshot ---------- */
.snapshot { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); overflow: hidden; }
.snap { background: var(--abyss); padding: clamp(1.6rem, 2.4vw, 2.2rem); }
.snap .k { font-family: var(--mono); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--brass); }
.snap ul { margin-top: 1.1rem; display: flex; flex-direction: column; gap: .55rem; }
.snap li { color: var(--fog); font-size: .9rem; line-height: 1.25; }
.snap .big { font-family: var(--serif); font-size: 2.2rem; color: var(--brass-soft); line-height: 1; display: block; margin-top: .6rem; }
.snap .sub { color: var(--mist); font-size: .82rem; margin-top: .5rem; }
@media (max-width: 920px) { .snapshot { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .snapshot { grid-template-columns: 1fr; } }

/* ---------- Credentials & compliance ---------- */
.creds { display: grid; grid-template-columns: repeat(auto-fit, minmax(232px, 1fr)); gap: 1.2rem; margin-top: 3rem; }
.cred { background: var(--white); border: 1px solid var(--paper-2); border-radius: var(--radius-lg); padding: 1.8rem; transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.cred:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); }
.cred .chk { width: 34px; height: 34px; border-radius: 50%; background: var(--paper); color: var(--brass-deep); display: grid; place-items: center; font-size: .95rem; margin-bottom: 1.1rem; }
.cred h4 { color: var(--ink); font-size: 1.08rem; }
.cred p { margin-top: .55rem; color: var(--slate); font-size: .9rem; line-height: 1.5; }
.cred .meta { margin-top: .9rem; font-family: var(--mono); font-size: .66rem; letter-spacing: .06em; text-transform: uppercase; color: var(--brass-deep); }

/* ---------- RFQ form ---------- */
.rfq { background: var(--white); border: 1px solid var(--paper-2); border-radius: var(--radius-lg); padding: clamp(1.6rem, 3vw, 2.6rem); }
.rfq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { display: flex; flex-direction: column; gap: .45rem; }
.field.full { grid-column: 1 / -1; }
.field label { font-family: var(--mono); font-size: .67rem; letter-spacing: .1em; text-transform: uppercase; color: var(--brass-deep); }
.field input, .field select, .field textarea { font-family: var(--sans); font-size: .98rem; color: var(--ink); padding: .85em 1em; border: 1px solid var(--paper-2); border-radius: var(--radius); background: var(--paper); transition: border-color .2s, box-shadow .2s, background .2s; width: 100%; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--brass); box-shadow: 0 0 0 3px rgba(194,160,99,.15); background: var(--white); }
.field textarea { resize: vertical; min-height: 120px; }
.rfq .btn { margin-top: 1.6rem; }
.rfq-note { margin-top: 1rem; font-size: .82rem; color: var(--slate); }

/* ---------- Big quote ---------- */
.quote { text-align: center; max-width: 28ch; margin-inline: auto; }
.quote p { font-family: var(--serif); font-size: var(--fs-h3); font-style: italic; line-height: 1.3; color: var(--white); }
.quote cite { display: block; margin-top: 1.6rem; font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--brass); font-style: normal; }

/* ---------- Future / AxBow ---------- */
.spec-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 1px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius-lg); overflow: hidden; margin-top: 2.5rem; }
.spec { background: var(--abyss); padding: 1.5rem; }
.spec .v { font-family: var(--serif); font-size: 1.7rem; color: var(--brass-soft); }
.spec .k { font-family: var(--mono); font-size: .66rem; letter-spacing: .12em; text-transform: uppercase; color: var(--mist); margin-top: .5rem; }
.multitask { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 2rem; }
.multitask span { font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; padding: .55em 1em; border-radius: var(--radius); color: var(--brass-soft); border: 1px solid rgba(194,160,99,.35); }

/* ---------- CTA band ---------- */
.cta-band { position: relative; overflow: hidden; background: var(--abyss-900); color: var(--white); text-align: center; }
.cta-band .pattern { position: absolute; inset: 0; opacity: .07; object-fit: cover; width: 100%; height: 100%; }
.cta-inner { position: relative; z-index: 2; max-width: 38ch; margin-inline: auto; }
.cta-inner h2 { margin: 1.2rem 0 1rem; }
.cta-inner p { color: var(--mist); margin-bottom: 2.2rem; }

/* ---------- Page hero (interior) ---------- */
.page-hero { background: var(--abyss-900); color: var(--white); padding-top: clamp(8rem, 16vh, 12rem); padding-bottom: clamp(3rem, 7vh, 5rem); position: relative; overflow: hidden; }
.page-hero .pattern { position: absolute; right: -4%; top: 0; height: 120%; opacity: .12; }
.page-hero h1 { max-width: 18ch; margin-top: 1.2rem; }
.page-hero p { max-width: 56ch; margin-top: 1.4rem; color: var(--mist); font-size: var(--fs-lead); font-weight: 300; }
.crumb { font-family: var(--mono); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--slate); }
.crumb a:hover { color: var(--brass-soft); }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4.5rem); }
.contact-block + .contact-block { margin-top: 2.2rem; }
.contact-block .k { font-family: var(--mono); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--brass-deep); margin-bottom: .6rem; }
.contact-block .v { font-size: 1.05rem; color: var(--ink); }
.contact-block .v a:hover { color: var(--brass-deep); }
.licenses { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1rem; }
.lic { font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; padding: .6em 1em; border-radius: var(--radius); background: var(--paper); border: 1px solid var(--paper-2); color: var(--steel); }
.lic b { color: var(--brass-deep); }

/* ---------- Footer ---------- */
.site-footer { background: var(--abyss-900); color: var(--mist); padding-block: clamp(3.5rem,6vw,5rem) 2.5rem; }
.foot-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2.5rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.foot-brand .brand { color: var(--white); margin-bottom: 1.3rem; }
.foot-brand p { max-width: 36ch; font-size: .92rem; }
.foot-col h5 { font-family: var(--mono); font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--slate); margin-bottom: 1.1rem; font-weight: 500; }
.foot-col a, .foot-col li { display: block; color: var(--fog); font-size: .92rem; padding-block: .35rem; }
.foot-col a:hover { color: var(--brass-soft); }
.foot-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; padding-top: 2rem; font-family: var(--mono); font-size: .7rem; letter-spacing: .06em; color: var(--slate); }
.foot-bottom .entities b { color: var(--mist); font-weight: 400; }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; } .reveal.d3 { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ---------- Lightbox ---------- */
.lightbox { position: fixed; inset: 0; z-index: 200; background: rgba(6,18,31,.94); display: none; place-items: center; padding: 5vw; }
.lightbox.open { display: grid; }
.lightbox img { max-width: 100%; max-height: 86vh; border-radius: var(--radius); box-shadow: var(--shadow); }
.lightbox .close { position: absolute; top: 1.4rem; right: 1.6rem; color: var(--white); font-family: var(--mono); font-size: .8rem; letter-spacing: .1em; }

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .split, .contact-grid { grid-template-columns: 1fr; }
  .split.flip { direction: ltr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(2) { border-right: 0; }
  .stat:nth-child(1), .stat:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,.08); }
  .vmv { grid-template-columns: 1fr; }
  .svc-grid { grid-template-columns: 1fr; }
  .foot-top { grid-template-columns: 1fr 1fr; }
  .foot-brand { grid-column: 1 / -1; }
  .trow { grid-template-columns: 70px 1fr; gap: .4rem 1rem; }
  .trow .vessel { grid-column: 2; }
  .trow .scope { grid-column: 2; }
}
@media (max-width: 760px) {
  .nav-links, .nav-cta .btn { display: none; }
  .nav-toggle { display: block; }
  .nav-links {
    position: fixed; inset: 0; flex-direction: column; justify-content: center;
    gap: 1.8rem; background: var(--abyss-900); transform: translateX(100%);
    transition: transform .5s var(--ease);
  }
  .nav-links a { font-family: var(--serif); font-size: 1.8rem; color: var(--white); }
  .nav-links a::after { display: none; }
  body.menu-open .nav-links { transform: none; display: flex; }
  body.menu-open { overflow: hidden; }
}
@media (max-width: 540px) {
  .stats { grid-template-columns: 1fr 1fr; }
  .page-hero .pattern { display: none; }
}
