/*
Theme Name: PK Global M&C
Theme URI: https://pkglobalmnc.com
Author: PK Global M&C Pte Ltd
Author URI: https://pkglobalmnc.com
Description: Official theme for PK Global M&C Pte Ltd — Marine Consultancy, Singapore.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Private
Text Domain: pkglobal
*/

:root{
  --ink:#144888;
  --ink-2:#1d5aa6;
  --ink-deep:#0c2e5e;
  --paper:#FFFFFF;
  --paper-2:#F3F5F8;
  --paper-3:#E8ECF2;
  --brass:#B08534;
  --brass-deep:#8A6622;
  --teal:#2A4A4F;
  --rule:rgba(20,72,136,.16);
  --rule-strong:rgba(20,72,136,.42);
  --muted:#6a7a8e;
  --paper-warm:#F7F4EF;
  --serif:"Newsreader", Georgia, serif;
  --sans:"Inter Tight", -apple-system, system-ui, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:var(--paper)}

/* ——— layout shell ——— */
.wrap{max-width:1320px;margin:0 auto;padding:0 40px}
@media (max-width:720px){ .wrap{padding:0 22px} }

/* ——— top bar ——— */
.topstrip{
  border-bottom:1px solid var(--rule);
  background:var(--paper);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}
.topstrip .wrap{display:flex;justify-content:space-between;padding-top:9px;padding-bottom:9px;gap:24px;flex-wrap:wrap}
.topstrip .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--brass);margin-right:8px;vertical-align:middle}

header.nav{
  border-bottom:1px solid rgba(255,255,255,.12);
  position:sticky;top:0;z-index:50;
  background:rgba(20,72,136,.97);
  backdrop-filter:saturate(120%) blur(8px);
}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px;gap:32px}

/* brand */
.brand{display:flex;align-items:center;gap:14px}
.brand-logo-img{height:42px;width:auto;display:block}
.brand-mark{width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(255,255,255,.55);display:grid;place-items:center;font-family:var(--serif);font-weight:500;font-size:18px;letter-spacing:-.02em;color:#fff;background:rgba(255,255,255,.1)}
.brand-name{font-family:var(--serif);font-size:20px;font-weight:500;letter-spacing:-.01em;line-height:1;color:#fff}
.brand-sub{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.52);margin-top:4px;text-transform:uppercase}

/* desktop nav links */
nav.primary{display:flex;gap:36px;font-size:14px;font-weight:500;letter-spacing:.01em}
nav.primary a{position:relative;padding:6px 0;color:rgba(255,255,255,.82);transition:color .18s}
nav.primary a:hover{color:#fff}
nav.primary a:hover::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:rgba(255,255,255,.45)}
nav.primary a.nav-current{color:#d4a830}
nav.primary a.nav-current::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:#d4a830}

/* CTA + hamburger wrapper */
.nav-right{display:flex;align-items:center;gap:16px}
.nav-cta{font-size:13px;font-weight:500;padding:11px 22px;background:#fff;color:var(--ink);border-radius:999px;transition:background .2s;letter-spacing:.01em;white-space:nowrap}
.nav-cta:hover{background:rgba(255,255,255,.88)}

/* hamburger button */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;width:40px;height:40px;flex-shrink:0}
.nav-burger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .22s,opacity .22s}
.nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:920px){nav.primary{display:none}.nav-cta{display:none}.nav-burger{display:flex}}

/* mobile nav — fixed overlay, sits below sticky header */
.mobile-nav{
  position:fixed;top:78px;left:0;right:0;
  z-index:49;
  background:#144888;
  border-top:1px solid rgba(255,255,255,.1);
  box-shadow:0 12px 32px rgba(0,0,0,.4);
  opacity:0;
  transform:translateY(-8px);
  pointer-events:none;
  transition:opacity .22s ease,transform .22s ease;
}
.mobile-nav.is-open{opacity:1;transform:translateY(0);pointer-events:auto}
@media(min-width:921px){.mobile-nav{display:none}}
.mobile-nav .wrap{display:flex;flex-direction:column;padding-top:8px;padding-bottom:28px}
.mobile-nav a{font-size:17px;font-weight:500;color:rgba(255,255,255,.85);padding:16px 0;border-bottom:1px solid rgba(255,255,255,.09);display:block;transition:color .15s}
.mobile-nav a:hover{color:#fff}
.mobile-nav a.nav-current{color:#d4a830}
.mobile-nav .mobile-nav-cta{margin-top:20px;display:block;text-align:center;background:#fff;color:var(--ink);border-radius:999px;padding:15px 24px;font-size:14px;font-weight:500;letter-spacing:.01em;border-bottom:none;transition:background .2s}
.mobile-nav .mobile-nav-cta:hover{background:rgba(255,255,255,.9)}

/* ——— hero ——— */
.hero{
  padding:64px 0 88px;
  border-bottom:1px solid var(--rule);
  position:relative;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap:72px;
  align-items:center;
}
@media (max-width:980px){ .hero-grid{grid-template-columns:1fr;gap:40px} .hero{padding:36px 0 64px} }

.hero-visual{
  position:relative;
  aspect-ratio: 5/4;
  background:var(--paper-2);
  overflow:hidden;
  border:1px solid var(--rule);
}
.hero-visual img{width:100%;height:100%;object-fit:cover;display:block}
.hero-visual .badge{
  position:absolute;top:18px;left:18px;
  background:var(--ink);color:var(--paper);
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  padding:8px 14px;z-index:2;pointer-events:none;
}
.hero-visual .coord{
  position:absolute;bottom:18px;right:18px;
  background:rgba(20,72,136,.92);color:var(--paper);
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;
  padding:8px 14px;z-index:2;pointer-events:none;
}

.eyebrow{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);
  display:flex;align-items:center;gap:14px;
  margin-bottom:36px;
}
.eyebrow .num{color:var(--brass-deep);font-weight:500}
.eyebrow .line{flex:0 0 60px;height:1px;background:var(--rule-strong)}

h1.display{
  font-family:var(--serif);
  font-weight:300;
  font-size: clamp(40px, 5.2vw, 76px);
  line-height:1.02;
  letter-spacing:-.022em;
  margin:0;
  color:var(--ink);
  text-wrap:balance;
}
h1.display em{
  font-style:italic;
  font-weight:400;
  color:var(--brass-deep);
}
h1.display .small{
  display:block;
  font-size:.36em;
  line-height:1.4;
  letter-spacing:-.005em;
  color:var(--muted);
  font-weight:300;
  margin-top:24px;
  font-style:normal;
  max-width:32ch;
}

.hero-meta{
  display:flex;flex-direction:column;gap:36px;
  margin-top:40px;
}
.hero-cta-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:999px;
  font-size:14px;font-weight:500;letter-spacing:.005em;
  transition:all .2s;
  cursor:pointer;border:none;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--ink-deep);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule-strong)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(11,31,51,.04)}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
  border-top:1px solid var(--rule);
  padding-top:24px;
}
.stat .n{
  font-family:var(--serif);
  font-size:42px;
  line-height:1;
  font-weight:400;
  letter-spacing:-.02em;
  color:var(--ink);
}
.stat .l{
  font-family:var(--mono);
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);
  margin-top:8px;
}

/* ——— section primitives ——— */
section{padding:96px 0;border-bottom:1px solid var(--rule)}
@media (max-width:720px){ section{padding:64px 0} }

.sec-head{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:48px;
  margin-bottom:56px;
  align-items:start;
}
@media (max-width:780px){ .sec-head{grid-template-columns:1fr;gap:18px;margin-bottom:40px} }

.sec-label{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);
  padding-top:12px;
  border-top:1px solid var(--ink);
}
.sec-label .idx{color:var(--brass-deep)}

h2.sec-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(34px,4.6vw,60px);
  line-height:1.04;
  letter-spacing:-.022em;
  margin:0 0 20px;
  text-wrap:balance;
}
h2.sec-title em{font-style:italic;color:var(--brass-deep);font-weight:400}
.sec-sub{
  font-family:var(--serif);
  font-size:18px;line-height:1.55;
  color:var(--muted);
  max-width:58ch;
  margin:0;
  text-wrap:pretty;
}

/* ——— services 4-column compare ——— */
.lob-cols{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
}
@media (max-width:980px){ .lob-cols{grid-template-columns:repeat(2,1fr)} }
@media (max-width:600px){ .lob-cols{grid-template-columns:1fr} }
.lob-col{
  padding:32px 28px 36px;
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;
  background:var(--paper);
  transition:background .25s;
  position:relative;
}
.lob-col:last-child{border-right:none}
.lob-col:hover{background:var(--paper-2)}
@media (max-width:980px){
  .lob-col:nth-child(2){border-right:none}
  .lob-col:nth-child(1),.lob-col:nth-child(2){border-bottom:1px solid var(--rule)}
}
@media (max-width:600px){
  .lob-col{border-right:none;border-bottom:1px solid var(--rule)}
  .lob-col:last-child{border-bottom:none}
}
.lob-col-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--brass-deep);
  margin-bottom:18px;
}
.lob-col-title{
  font-family:var(--serif);font-weight:400;
  font-size:24px;line-height:1.15;letter-spacing:-.012em;
  margin:0 0 12px;
}
.lob-col-cat{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin-bottom:18px;
  border-bottom:1px solid var(--rule);padding-bottom:14px;
}
.lob-col p{
  font-size:14px;line-height:1.55;color:var(--ink);
  margin:0 0 18px;
}
.lob-col ul{
  list-style:none;padding:0;margin:0 0 22px;
  display:flex;flex-direction:column;gap:8px;
}
.lob-col ul li{
  font-size:13px;line-height:1.45;color:var(--ink);
  padding-left:18px;position:relative;
}
.lob-col ul li::before{
  content:"";position:absolute;left:0;top:8px;
  width:8px;height:1px;background:var(--brass);
}
.lob-col-foot{
  margin-top:auto;padding-top:18px;border-top:1px solid var(--rule);
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;
  color:var(--ink);
}
.lob-col-foot .arr{transition:transform .2s}
.lob-col:hover .lob-col-foot .arr{transform:translateX(4px);color:var(--brass-deep)}

/* ——— equipment partners ——— */
.partners-wrap{background:var(--ink);color:var(--paper);border-bottom:none;margin:0;padding:96px 0}
.partners-wrap .sec-label{border-top-color:rgba(244,239,230,.4);color:rgba(244,239,230,.6)}
.partners-wrap .sec-label .idx{color:var(--brass)}
.partners-wrap h2.sec-title{color:var(--paper)}
.partners-wrap h2.sec-title em{color:var(--brass)}
.partners-wrap .sec-sub{color:rgba(244,239,230,.7)}
.partners-list{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid rgba(244,239,230,.18)}
.pn{
  display:grid;
  grid-template-columns: 48px 88px 1fr 1.3fr 180px;
  gap:28px;
  padding:24px 0;
  border-bottom:1px solid rgba(244,239,230,.18);
  align-items:center;
  transition:padding .2s;
  color:inherit;
  text-decoration:none;
}
.pn:hover{padding-left:12px}
.pn:hover .pn-name{color:var(--brass)}
@media (max-width:880px){ .pn{grid-template-columns:64px 1fr;gap:14px;padding:22px 0} .pn-cat,.pn-origin,.pn-idx{display:none} }
.pn-idx{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:rgba(244,239,230,.5)}
.pn-logo{
  width:110px;height:80px;
  background:#ffffff;
  border:1px solid #cdd5de;
  display:grid;place-items:center;
  overflow:hidden;
  padding:8px;
}
.pn-logo img{width:100%;height:100%;object-fit:contain;display:block}
@media (max-width:880px){ .pn-logo{width:80px;height:60px} }
.pn-name{
  font-family:var(--serif);
  font-size:clamp(22px,2.2vw,30px);
  font-weight:400;
  letter-spacing:-.015em;
  transition:color .25s;
}
.pn-name span{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,239,230,.55);margin-top:6px;font-weight:400}
.pn-cat{font-size:14px;line-height:1.5;color:rgba(244,239,230,.78);max-width:48ch}
.pn-origin{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(244,239,230,.5);
  text-align:right;
}
.pn-origin b{color:var(--brass);font-weight:500}

/* ——— shipyard network ——— */
.yards-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:48px;
  align-items:start;
}

.map-wrap{
  position:relative;
  background:var(--ink);
  padding:32px 32px 24px;
  border:1px solid var(--rule);
  overflow:hidden;
}
@media (max-width:720px){ .map-wrap{padding:18px} }
.map-wrap::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(244,239,230,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244,239,230,.04) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events:none;
}
.map-frame{
  position:relative;
  width:100%;
  aspect-ratio: 2 / 1;
}
.map-svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.map-svg .land{fill:rgba(244,239,230,.14);stroke:rgba(244,239,230,.28);stroke-width:.4}
.pin{cursor:pointer}
.pin .ring{fill:none;stroke:var(--brass);stroke-width:1.4;opacity:.6;transform-origin:center;transform-box:fill-box}
.pin .core{fill:var(--brass)}
.pin .label{
  font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  fill:var(--paper);
  pointer-events:none;
  opacity:.85;
}
.pin .count{
  font-family:var(--serif);font-size:13px;font-weight:500;
  fill:var(--brass);
  pointer-events:none;
}
@keyframes pinpulse{ 0%{r:6;opacity:.7} 100%{r:18;opacity:0} }
.pin .ring{animation:pinpulse 2.4s ease-out infinite}
.pin:nth-of-type(2n) .ring{animation-delay:.4s}
.pin:nth-of-type(3n) .ring{animation-delay:.9s}
.pin:nth-of-type(5n) .ring{animation-delay:1.4s}
.pin:nth-of-type(7n) .ring{animation-delay:1.9s}
.pin:hover .core{r:7}

.map-legend{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:18px;margin-top:24px;
  border-top:1px solid rgba(244,239,230,.18);
  flex-wrap:wrap;gap:14px;
}
.map-legend .lg-l{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,239,230,.55);display:flex;align-items:center;gap:10px}
.map-legend .lg-dot{width:10px;height:10px;border-radius:50%;background:var(--brass);box-shadow:0 0 0 3px rgba(201,162,74,.2)}
.map-legend .lg-r{font-family:var(--serif);font-size:14px;color:var(--paper);font-style:italic}

.yards-bottom{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap:48px;
  align-items:start;
}
@media (max-width:880px){ .yards-bottom{grid-template-columns:1fr;gap:32px} }

.regions-strip{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  border-top:1px solid var(--rule);
  border-left:1px solid var(--rule);
}
@media (max-width:780px){ .regions-strip{grid-template-columns:repeat(2,1fr)} }
.region{
  display:flex;flex-direction:column;
  padding:18px 16px;
  border-bottom:1px solid var(--rule);
  border-right:1px solid var(--rule);
  gap:6px;
  background:var(--paper);
  transition:background .2s;
}
.region:hover{background:var(--paper-2)}
.region-count{
  font-family:var(--serif);font-size:30px;font-weight:300;color:var(--ink);
  line-height:1;letter-spacing:-.02em;
}
.region-name{font-family:var(--sans);font-size:13px;font-weight:500;color:var(--ink)}

.yards-side h3{
  font-family:var(--serif);font-weight:400;font-size:28px;
  line-height:1.2;margin:0 0 16px;letter-spacing:-.015em;
}
.yards-side p{font-size:15px;line-height:1.6;color:var(--ink);margin:0 0 14px}
.case-card{
  margin-top:32px;
  padding:28px;
  background:var(--paper-2);
  border-radius:4px;
}
.case-card .case-eyebrow{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brass-deep);margin-bottom:10px;
}
.case-card blockquote{
  font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.5;
  margin:0;color:var(--ink);
}

/* ——— leadership ——— */
.leader{
  display:grid;
  grid-template-columns: 1fr;
  gap:48px;
  align-items:start;
}
.leader-photo{
  width:100%;
  background:var(--paper-2);
  position:relative;
}
.leader-photo img{width:100%;height:auto;display:block}
.leader-meta{
  position:absolute;left:20px;bottom:20px;right:20px;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper);
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  pointer-events:none;
}
.leader-text-grid{
  display:grid;
  grid-template-columns: 1fr 1.4fr;
  gap:64px;
  align-items:start;
}
@media (max-width:880px){ .leader-text-grid{grid-template-columns:1fr;gap:24px} }
.leader-text .role{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brass-deep);margin-bottom:18px;
}
.leader-text p{font-size:16px;line-height:1.6;color:var(--ink);max-width:60ch;margin:0 0 16px}
.leader-text p.kicker{
  font-family:var(--serif);font-size:22px;line-height:1.45;font-weight:400;
  color:var(--ink);margin:0;text-wrap:pretty;
}
.signature{
  margin-top:28px;
  font-family:var(--serif);font-style:italic;
  color:var(--muted);
  border-top:1px solid var(--rule);padding-top:18px;
  font-size:14px;
}

/* ——— projects ——— */
.projects{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
@media (max-width:980px){ .projects{grid-template-columns:1fr} }
.proj{
  display:flex;flex-direction:column;
  background:var(--paper);
  border:1px solid var(--rule);
  transition:all .25s;
  cursor:pointer;
  overflow:hidden;
}
.proj:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(11,31,51,.2)}
.proj-img{aspect-ratio:4/3;background:var(--paper-2);position:relative;overflow:hidden}
.proj-img img{width:100%;height:100%;object-fit:cover;display:block}
.proj-img .ribbon{
  position:absolute;top:14px;left:14px;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--paper);background:var(--ink);padding:5px 10px;
  z-index:2;pointer-events:none;
}
.proj-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.proj-cat{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:10px}
.proj-title{font-family:var(--serif);font-size:24px;line-height:1.15;font-weight:400;letter-spacing:-.012em;margin:0 0 12px}
.proj-desc{font-size:14px;line-height:1.55;color:var(--muted);margin:0 0 22px;flex:1}
.proj-link{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--rule);padding-top:14px}
.proj-link .arr{transition:transform .2s}
.proj:hover .proj-link .arr{transform:translateX(4px)}

/* ——— trust strip ——— */
.trust{
  background:var(--paper-2);
  padding:48px 0;border-bottom:1px solid var(--rule);
}
.trust-inner{display:flex;align-items:center;gap:48px;flex-wrap:wrap;justify-content:space-between}
.trust-label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);flex:0 0 auto;max-width:200px;line-height:1.6}
.trust-marks{display:flex;flex:1;flex-wrap:wrap;gap:36px 56px;align-items:center;justify-content:flex-end}
.trust-mark{
  font-family:var(--serif);font-size:18px;letter-spacing:-.005em;color:var(--ink);opacity:.7;
  transition:opacity .2s;display:flex;align-items:baseline;gap:10px;
}
.trust-mark:hover{opacity:1}
.tm-num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted);flex-shrink:0}

/* ——— contact ——— */
.contact-block{
  background:var(--ink);color:var(--paper);
  padding:0;border-bottom:none;
}
.contact-block .wrap{padding-top:120px;padding-bottom:60px}
.contact-grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr;
  gap:80px;
  align-items:start;
}
@media (max-width:880px){ .contact-grid{grid-template-columns:1fr;gap:24px} .contact-block .wrap{padding-top:36px;padding-bottom:36px} }
.contact-block h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,5.6vw,76px);
  line-height:1;letter-spacing:-.025em;
  color:var(--paper);margin:0 0 28px;text-wrap:balance;
}
.contact-block h2 em{font-style:italic;color:var(--brass);font-weight:400}
.contact-block p.lede{
  font-family:var(--serif);font-size:20px;line-height:1.5;
  color:rgba(244,239,230,.78);max-width:46ch;margin:0 0 18px;
}
.contact-info{display:flex;flex-direction:column;gap:12px;border-top:1px solid rgba(244,239,230,.2);padding-top:16px}
.ci-row{display:flex;justify-content:space-between;gap:20px;align-items:baseline}
.ci-label{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,239,230,.5)}
.ci-val{font-family:var(--serif);font-size:20px;color:var(--paper);font-weight:400;text-align:right}
.ci-val a:hover{color:var(--brass)}

.form{
  background:rgba(244,239,230,.06);
  padding:36px;
  border:1px solid rgba(244,239,230,.18);
}
.form .row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,239,230,.6)}
.form input,.form select,.form textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(244,239,230,.3);
  color:var(--paper);font-family:var(--sans);font-size:15px;padding:10px 0 12px;
  transition:border-color .2s;
  outline:none;
  width:100%;
}
.form input:focus,.form textarea:focus,.form select:focus{border-bottom-color:var(--brass)}
.form textarea{min-height:80px;resize:vertical}
.form select{appearance:none}
.form select option{background:var(--ink)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:600px){ .form-row-2{grid-template-columns:1fr} }
.form .submit{
  width:100%;
  padding:16px 24px;background:var(--brass);color:var(--ink);
  border:none;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;transition:all .2s;margin-top:14px;
}
.form .submit:hover{background:#c69739}

/* ——— contact form 7 overrides ——— */
.contact-block .wpcf7-form{
  background:rgba(244,239,230,.06);
  padding:18px;
  border:1px solid rgba(244,239,230,.18);
}
.contact-block .wpcf7-form .row{display:flex;flex-direction:column;gap:3px;margin-bottom:9px}
.contact-block .wpcf7-form label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,239,230,.6)}
.contact-block .wpcf7-form-control-wrap{display:block;width:100%}
.contact-block .wpcf7-form-control{
  background:transparent;border:none;border-bottom:1px solid rgba(244,239,230,.3);
  color:var(--paper);font-family:var(--sans);font-size:15px;padding:10px 0 12px;
  transition:border-color .2s;outline:none;width:100%;
}
.contact-block .wpcf7-form-control:focus{border-bottom-color:var(--brass)}
.contact-block .wpcf7-form textarea.wpcf7-form-control{min-height:80px;resize:vertical}
.contact-block .wpcf7-form select.wpcf7-form-control{appearance:none}
.contact-block .wpcf7-form select.wpcf7-form-control option{background:var(--ink)}
.contact-block .wpcf7-form .submit{
  width:100%;
  padding:16px 24px;background:var(--brass);color:var(--ink);
  border:none;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;transition:all .2s;margin-top:14px;display:block;
}
.contact-block .wpcf7-form .submit:hover{background:#c69739}
.contact-block .wpcf7-not-valid-tip{font-family:var(--mono);font-size:10px;color:#e07070;margin-top:4px}
.contact-block .wpcf7-response-output{font-family:var(--mono);font-size:11px;letter-spacing:.1em;margin-top:16px;padding:12px 16px;border:1px solid rgba(244,239,230,.2);color:var(--paper)}

/* ——— footer ——— */
footer{background:var(--ink);color:rgba(244,239,230,.6);font-size:13px;border-top:1px solid rgba(244,239,230,.12)}
footer .wrap{padding-top:48px;padding-bottom:48px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center}
footer nav{display:flex;gap:32px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
footer nav a:hover{color:var(--brass)}
footer .copy{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}

/* ═══════════════════════════════════════════════════════════
   Shipyards page
   ═══════════════════════════════════════════════════════════ */

/* active nav link — rules live in the nav block above */

/* page hero */
.page-hero{border-bottom:1px solid var(--rule)}
.ph-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:14px;padding:28px 0 20px}
.ph-eyebrow .line{flex:0 0 48px;height:1px;background:var(--rule-strong)}
.ph-eyebrow .idx{color:var(--brass-deep)}
.ph-grid{display:grid;grid-template-columns:2fr 3fr;gap:0;border-top:1px solid var(--rule)}
@media(max-width:900px){.ph-grid{grid-template-columns:1fr}}
.ph-left{padding:32px 48px 36px 0;border-right:1px solid var(--rule);display:flex;flex-direction:column;gap:20px}
@media(max-width:900px){.ph-left{border-right:none;padding-right:0;padding-bottom:28px;border-bottom:1px solid var(--rule)}}
.ph-title{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.6vw,50px);line-height:1.04;letter-spacing:-.022em;text-wrap:balance}
.ph-title em{font-style:italic;font-weight:400;color:var(--brass-deep)}
.ph-desc{font-family:var(--serif);font-size:15px;line-height:1.6;color:var(--muted);max-width:44ch;text-wrap:pretty}
.ph-stats{display:flex;gap:0;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--rule)}
.ph-stat{padding:0 28px;border-right:1px solid var(--rule)}
.ph-stat:first-child{padding-left:0}
.ph-stat:last-child{border-right:none}
.ph-stat .n{font-family:var(--serif);font-size:28px;font-weight:300;line-height:1;letter-spacing:-.02em}
.ph-stat .l{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:5px}
.ph-contact{margin-top:auto;padding-top:20px;border-top:1px solid var(--rule)}
.ph-contact-label{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.ph-contact-line{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink);margin-bottom:6px}
.ph-contact-line:last-child{margin-bottom:0}
.ph-contact-icon{width:18px;height:18px;flex:0 0 auto;color:var(--brass-deep)}
.ph-contact-val{font-weight:500;letter-spacing:.01em}
.ph-contact-val a{color:var(--ink);transition:color .18s}
.ph-contact-val a:hover{color:var(--brass-deep)}
.ph-values{display:flex;flex-direction:column}
.ph-val-row{padding:22px 0 22px 40px;border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:8px;transition:background .18s}
.ph-val-row:last-child{border-bottom:none}
.ph-val-row:hover{background:rgba(20,72,136,.025)}
.ph-val-head{display:flex;align-items:center;gap:14px}
.ph-val-num{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-deep);flex:0 0 auto}
.ph-val-sep{width:1px;height:22px;background:var(--rule-strong);flex:0 0 auto}
.ph-val-title{font-family:var(--serif);font-size:clamp(15px,1.5vw,18px);font-weight:400;letter-spacing:-.01em}
.ph-val-desc{font-size:13.5px;line-height:1.7;color:var(--muted);text-wrap:pretty}

/* filter bar */
.filterbar{position:sticky;top:78px;z-index:40;background:rgba(255,255,255,.96);backdrop-filter:saturate(120%) blur(6px);border-bottom:1px solid var(--rule);padding:14px 0}
.filterbar .wrap{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
@media(max-width:600px){.filterbar .wrap{gap:10px}}
.search-wrap{position:relative;flex:0 0 240px}
@media(max-width:780px){.search-wrap{flex:1 1 160px}}
.search-wrap input{width:100%;padding:9px 14px 9px 36px;border:1px solid var(--rule-strong);border-radius:999px;font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--paper-2);outline:none;transition:border-color .2s}
.search-wrap input:focus{border-color:var(--ink);background:var(--paper)}
.search-wrap .search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:14px;pointer-events:none;line-height:1}
.filter-divider{width:1px;height:24px;background:var(--rule);flex:0 0 auto}
@media(max-width:600px){.filter-divider{display:none}}
.chips{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;padding:7px 14px;border-radius:999px;border:1px solid var(--rule);cursor:pointer;transition:all .18s;background:var(--paper);color:var(--ink);white-space:nowrap}
.chip:hover{border-color:var(--ink);background:var(--paper-2)}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.count-badge{margin-left:5px;opacity:.6;font-size:.9em}
.cap-filter-wrap{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.cap-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.cap-select{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:7px 28px 7px 12px;border:1px solid var(--rule);border-radius:999px;appearance:none;cursor:pointer;background:var(--paper) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23144888' opacity='.5'/%3E%3C/svg%3E") no-repeat right 12px center;color:var(--ink);outline:none}

/* yard grid */
.sh-main{max-width:1320px;margin:0 auto;padding:40px 40px 80px}
@media(max-width:600px){.sh-main{padding:28px 22px 60px}}
.results-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.results-count{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.results-count b{color:var(--ink);font-weight:500}
.yard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:640px){.yard-grid{grid-template-columns:1fr}}
.empty-state{padding:80px 0;text-align:center;color:var(--muted)}
.empty-state h3{font-family:var(--serif);font-size:28px;font-weight:300;margin:0 0 10px}
.empty-state p{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}

/* yard card */
.yard-card{display:flex;flex-direction:column;border:1px solid var(--rule);background:var(--paper);cursor:pointer;transition:all .22s;overflow:hidden}
.yard-card:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(20,72,136,.18)}
.yard-card-img{aspect-ratio:16/9;background:var(--paper-2);position:relative;overflow:hidden;flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.yard-region-badge{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;background:var(--ink);color:var(--paper);padding:4px 10px;z-index:2;pointer-events:none}
.yard-card-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1;gap:10px}
.yard-name{font-family:var(--serif);font-size:20px;font-weight:400;letter-spacing:-.01em;line-height:1.15}
.yard-location{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.yard-caps{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;flex:1}
.yard-cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--rule);color:var(--muted)}
.yard-docks-row{padding:9px 0;border-top:1px solid var(--rule);display:flex;flex-direction:column;gap:2px}
.yard-docks-lbl{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.yard-docks-val{font-family:var(--sans);font-size:13px;font-weight:500;color:var(--ink-2);line-height:1.3}
.yard-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink)}
.yard-card-footer .arr{transition:transform .2s}
.yard-card:hover .yard-card-footer .arr{transform:translateX(4px);color:var(--brass-deep)}

/* modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(12,46,94,.55);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:40px 24px;overflow-y:auto}
.modal-backdrop.open{display:flex}
.modal{background:var(--paper);width:100%;max-width:900px;position:relative;margin:auto}
.modal-close{position:absolute;top:18px;right:18px;z-index:10;width:36px;height:36px;border-radius:50%;border:1px solid var(--rule);background:var(--paper);cursor:pointer;display:grid;place-items:center;font-size:16px;color:var(--ink);transition:all .18s}
.modal-close:hover{background:var(--ink);color:var(--paper)}
.modal-img-strip{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--rule)}
@media(max-width:640px){.modal-img-strip{grid-template-columns:1fr}}
.modal-img-a{aspect-ratio:16/9;position:relative;overflow:hidden;background:var(--paper-2)}
.modal-img-b{aspect-ratio:16/9;position:relative;overflow:hidden;background:#E8ECF2;border-left:1px solid var(--rule)}
@media(max-width:640px){.modal-img-b{border-left:none;border-top:1px solid var(--rule)}}
.modal-img-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.modal-body{padding:36px 40px 48px;display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media(max-width:640px){.modal-body{grid-template-columns:1fr;gap:28px;padding:28px 24px 40px}}
.modal-region-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:14px}
.modal-region-badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brass);flex:0 0 auto}
.modal-title{font-family:var(--serif);font-size:clamp(24px,3.5vw,36px);font-weight:400;letter-spacing:-.018em;line-height:1.1;margin:0 0 8px}
.modal-loc{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.modal-desc{font-size:15px;line-height:1.65;color:var(--ink);margin-bottom:22px;max-width:52ch;text-wrap:pretty}
.modal-caps-title{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;margin-top:4px}
.modal-caps{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.modal-cap{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border:1px solid var(--rule);color:var(--ink)}
.modal-cap.highlight{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.modal-cta{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;border-radius:999px;background:var(--ink);color:var(--paper);font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.03em;cursor:pointer;border:none;transition:background .2s;margin-top:auto}
.modal-cta:hover{background:var(--ink-deep)}
.modal-specs{display:flex;flex-direction:column;border-top:1px solid var(--rule)}
.spec-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--rule);align-items:baseline}
.spec-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.spec-val{font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink);text-align:right}
.modal-dock-section{padding:0 40px 48px;border-top:1px solid var(--rule)}
@media(max-width:640px){.modal-dock-section{padding:0 24px 40px}}
.dock-section-title{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);padding:20px 0 12px}
.dock-table{width:100%;border-collapse:collapse}
.dock-table th{font-family:var(--mono);font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);padding:8px 14px;text-align:left;border-bottom:1.5px solid var(--rule-strong);white-space:nowrap}
.dock-table th:not(:first-child){text-align:right}
.dock-table td{font-family:var(--sans);font-size:14px;color:var(--ink);padding:11px 14px;border-bottom:1px solid var(--rule);vertical-align:middle}
.dock-table td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums;font-weight:500}
.dock-table td:first-child{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted)}
.dock-table tr:last-child td{border-bottom:none}
.dock-table .dash{color:var(--rule-strong)}
.yard-card-img img{width:100%;height:100%;object-fit:cover}
.modal-img-a img,.modal-img-b img{width:100%;height:100%;object-fit:cover}
.modal-img-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:12px;text-align:center}

/* ═══════════════════════════════════════════════════════════
   Equipment page
   ═══════════════════════════════════════════════════════════ */

/* eyebrow separator — equipment uses .eline, shipyards uses .line */
.ph-eyebrow .eline{flex:0 0 48px;height:1px;background:var(--rule-strong)}
.section-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:14px;margin-bottom:20px}
.section-eyebrow .eline{flex:0 0 40px;height:1px;background:var(--rule-strong)}
.section-eyebrow .idx{color:var(--brass-deep)}

/* hero overrides — scoped to equipment template body class */
.page-template-page-equipment .page-hero{padding:56px 0 52px}
.page-template-page-equipment .ph-title{font-size:clamp(36px,5vw,66px);line-height:1.02}
.page-template-page-equipment .ph-grid{grid-template-columns:1fr 1fr;gap:64px;align-items:end;border-top:none}
@media(max-width:780px){.page-template-page-equipment .ph-grid{grid-template-columns:1fr;gap:24px}}
.page-template-page-equipment .ph-desc{font-size:17px;line-height:1.55;max-width:50ch;margin-bottom:20px}
.page-template-page-equipment .ph-stats{gap:36px;padding-top:18px}
.page-template-page-equipment .ph-stat .n{font-size:34px}
.page-template-page-equipment .ph-stat .l{font-size:10px;margin-top:6px}

/* vessel diagram */
.vessel-section{background:#07111e;padding:48px 0 40px;border-bottom:2px solid rgba(180,133,52,.25)}
.vessel-hint{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);text-align:center;margin-bottom:28px;display:flex;align-items:center;justify-content:center;gap:12px}
.vessel-hint::before,.vessel-hint::after{content:'';flex:0 0 32px;height:1px;background:rgba(255,255,255,.12)}
.vessel-wrap{position:relative;max-width:1320px;margin:0 auto;padding:0 40px}
@media(max-width:600px){.vessel-wrap{padding:0 16px}}
.vessel-svg{width:100%;height:auto;display:block;overflow:visible}

/* hotspot markers */
.hs{position:absolute;transform:translate(-50%,-50%);cursor:pointer;z-index:10}
.hs-core{width:12px;height:12px;border-radius:50%;background:var(--brass);position:relative;transition:transform .2s,background .2s}
.hs-core::before{content:'';position:absolute;inset:-7px;border-radius:50%;border:1.5px solid var(--brass);opacity:.5;animation:hspulse 2.2s ease-out infinite}
.hs-core::after{content:'';position:absolute;inset:-14px;border-radius:50%;border:1px solid var(--brass);opacity:.2;animation:hspulse 2.2s ease-out infinite .6s}
@keyframes hspulse{0%{transform:scale(.7);opacity:.7}100%{transform:scale(1.5);opacity:0}}
.hs.active .hs-core{background:#d4a830;transform:scale(1.4)}
.hs.active .hs-core::before,.hs.active .hs-core::after{animation:none;opacity:0}

/* tooltip */
.hs-tooltip{position:absolute;z-index:30;background:rgba(8,18,30,.96);border:1px solid rgba(176,133,52,.45);padding:18px 20px 16px;min-width:230px;max-width:285px;pointer-events:all;box-shadow:0 12px 40px rgba(0,0,0,.5);display:none}
.hs-tooltip.visible{display:block}
.tt-close{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;border:1px solid rgba(176,133,52,.3);background:none;color:rgba(255,255,255,.5);cursor:pointer;font-size:12px;display:grid;place-items:center;transition:all .15s}
.tt-close:hover{background:rgba(176,133,52,.2);color:#fff}
.tt-category{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:8px}
.tt-brand{font-family:var(--serif);font-size:17px;font-weight:400;color:#fff;line-height:1.2;margin-bottom:6px}
.tt-products{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:rgba(255,255,255,.45);margin-bottom:10px;line-height:1.5}
.tt-desc{font-size:13px;line-height:1.6;color:rgba(255,255,255,.62);margin-bottom:14px;text-wrap:pretty}
.tt-link{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);cursor:pointer;display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:0;transition:color .15s}
.tt-link:hover{color:#d4a830}

/* equipment brand grid */
.equip-section{padding:72px 0 80px;border-bottom:1px solid var(--rule)}
.equip-header{margin-bottom:40px}
.equip-title{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3.5vw,42px);letter-spacing:-.018em;line-height:1.08}
.equip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
@media(max-width:1000px){.equip-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.equip-grid{grid-template-columns:1fr}}
.brand-card{background:var(--paper);padding:28px 24px 24px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:all .22s;position:relative}
.brand-card::after{content:'';position:absolute;inset:0;border:2px solid var(--brass);opacity:0;pointer-events:none;transition:opacity .2s}
.brand-card:hover::after,.brand-card.highlighted::after{opacity:1}
.brand-card:hover{background:var(--paper-2)}
.brand-card.highlighted{background:#fffbf3}
.brand-logo{height:52px;display:flex;align-items:center;margin-bottom:4px}
.brand-logo img{max-height:44px;width:auto;max-width:140px;object-fit:contain;object-position:left center}
.brand-logo-text{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.brand-cat{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep)}
.brand-name-text{font-family:var(--serif);font-size:21px;font-weight:400;line-height:1.2;color:var(--ink)}
.brand-desc{font-size:13.5px;line-height:1.65;color:var(--muted);text-wrap:pretty;flex:1}
.brand-products{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.brand-prod-tag{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border:1px solid var(--rule);color:var(--muted)}
.brand-card-link{display:block;margin-top:auto}
.brand-profile-link{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);display:inline-flex;align-items:center;gap:5px;margin-top:12px;transition:color .15s}
.brand-profile-link:hover{color:var(--brass)}

/* ——— equipment brand profile pages ——— */

/* breadcrumb */
.bp-breadcrumb{padding:14px 0;border-bottom:1px solid var(--rule);background:var(--paper-2)}
.bp-breadcrumb .wrap{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.bp-breadcrumb a{color:var(--muted);transition:color .15s}
.bp-breadcrumb a:hover{color:var(--ink)}
.bp-breadcrumb .sep{opacity:.4}
.bp-breadcrumb .current{color:var(--ink)}

/* brand hero */
.bh-section{background:var(--ink-deep);padding:72px 0 64px;border-bottom:3px solid var(--brass)}
.bh-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:860px){.bh-grid{grid-template-columns:1fr;gap:40px}}
.bh-left{}
.bh-logo-wrap{margin-bottom:28px}
.bh-logo-wrap img{max-height:56px;width:auto;max-width:200px;object-fit:contain;object-position:left center;filter:brightness(0) invert(1)}
.bh-logo-text{font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.bh-cat{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.bh-cat::before{content:'';width:28px;height:1px;background:var(--brass)}
.bh-name{font-family:var(--serif);font-weight:300;font-size:clamp(28px,4vw,52px);letter-spacing:-.02em;line-height:1.06;color:#fff;margin-bottom:18px}
.bh-tagline{font-size:16px;line-height:1.65;color:rgba(255,255,255,.58);max-width:46ch;text-wrap:pretty}
.bh-right{}
.img-placeholder{background:rgba(255,255,255,.05);border:1px dashed rgba(255,255,255,.15);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:rgba(255,255,255,.25);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;text-align:center}
.img-placeholder::before{content:'';width:36px;height:36px;border:2px dashed rgba(255,255,255,.2);border-radius:50%;display:block}
.bh-img-ph{width:100%;aspect-ratio:4/3;border-radius:2px}
@media(max-width:860px){.bh-img-ph{max-width:420px}}

/* about section */
.bp-about{padding:72px 0 64px;border-bottom:1px solid var(--rule)}
.bp-about-grid{display:grid;grid-template-columns:1fr 400px;gap:64px;align-items:start}
@media(max-width:1000px){.bp-about-grid{grid-template-columns:1fr;gap:40px}}
.bp-about-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:18px;display:flex;align-items:center;gap:12px}
.bp-about-eyebrow::after{content:'';flex:0 0 40px;height:1px;background:var(--rule-strong)}
.bp-about-title{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3vw,38px);letter-spacing:-.018em;line-height:1.1;color:var(--ink);margin-bottom:24px}
.bp-about-body{font-size:15.5px;line-height:1.72;color:var(--muted);text-wrap:pretty;display:flex;flex-direction:column;gap:16px}
.bp-about-body p{margin:0}
.fact-card{background:var(--paper-warm);border-left:3px solid var(--brass);padding:32px 28px;display:flex;flex-direction:column;gap:0}
.fact-card-title{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:24px}
.fact-row{padding:14px 0;border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:4px}
.fact-row:last-child{border-bottom:none}
.fact-label{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.fact-value{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--ink);line-height:1.2}

/* products section */
.bp-products{padding:72px 0 80px;border-bottom:1px solid var(--rule);background:var(--paper-2)}
.bp-products-header{margin-bottom:44px}
.bp-products-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.bp-products-eyebrow::after{content:'';flex:0 0 40px;height:1px;background:var(--rule-strong)}
.bp-products-title{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3vw,38px);letter-spacing:-.018em;line-height:1.1;color:var(--ink)}
.bp-products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:720px){.bp-products-grid{grid-template-columns:1fr}}
.product-card{background:var(--paper);border:1px solid var(--rule);display:flex;flex-direction:column}
.product-card-img{aspect-ratio:16/9}
.product-card-img .img-placeholder{height:100%;background:var(--paper-3);border:none;border-bottom:1px solid var(--rule);color:var(--muted)}
.product-card-img .img-placeholder::before{border-color:var(--rule-strong)}
.product-card-body{padding:24px 22px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.product-card-cat{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep)}
.product-card-name{font-family:var(--serif);font-size:20px;font-weight:400;line-height:1.2;color:var(--ink)}
.product-card-desc{font-size:14px;line-height:1.65;color:var(--muted);flex:1;text-wrap:pretty}
.product-card-specs{margin-top:8px;display:flex;flex-direction:column;gap:0}
.product-specs .spec-row{display:grid;grid-template-columns:140px 1fr;gap:8px;padding:8px 0;border-top:1px solid var(--rule);font-size:12.5px}
.product-specs .spec-row:last-child{}
.product-specs .spec-label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);align-self:center}
.product-specs .spec-val{color:var(--ink)}

/* role section */
.bp-role{background:var(--ink-deep);padding:64px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.bp-role-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:800px){.bp-role-grid{grid-template-columns:1fr;gap:36px}}
.bp-role-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.bp-role-eyebrow::before{content:'';width:24px;height:1px;background:var(--brass)}
.bp-role-title{font-family:var(--serif);font-weight:300;font-size:clamp(22px,3vw,36px);letter-spacing:-.018em;line-height:1.1;color:#fff;margin-bottom:0}
.bp-role-body{font-size:15px;line-height:1.72;color:rgba(255,255,255,.58);text-wrap:pretty;display:flex;flex-direction:column;gap:14px}
.bp-role-body p{margin:0}
.bp-role-list{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:10px}
.bp-role-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:rgba(255,255,255,.55);line-height:1.55}
.bp-role-list li::before{content:'';flex:0 0 6px;width:6px;height:6px;border-radius:50%;background:var(--brass);margin-top:6px}

/* CTA section */
.bp-cta{padding:72px 0;background:var(--paper-warm);border-bottom:1px solid var(--rule)}
.bp-cta-inner{max-width:640px}
.bp-cta-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.bp-cta-title{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3vw,40px);letter-spacing:-.018em;line-height:1.08;color:var(--ink);margin-bottom:16px}
.bp-cta-sub{font-size:16px;line-height:1.65;color:var(--muted);margin-bottom:32px;text-wrap:pretty}
.bp-cta-btns{display:flex;gap:14px;flex-wrap:wrap}
.bp-cta-primary{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;padding:14px 28px;transition:background .18s}
.bp-cta-primary:hover{background:var(--ink-2)}
.bp-cta-secondary{display:inline-flex;align-items:center;gap:10px;color:var(--ink);font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;padding:14px 28px;border:1px solid var(--rule-strong);transition:all .18s}
.bp-cta-secondary:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ═══════════════════════════════════════════════════════════
   About page
   ═══════════════════════════════════════════════════════════ */

/* hero overrides — scoped to about template body class */
.page-template-page-about .page-hero{padding:60px 0 56px}
.page-template-page-about .ph-grid{grid-template-columns:1fr 1fr;gap:64px;align-items:end;border-top:none}
@media(max-width:780px){.page-template-page-about .ph-grid{grid-template-columns:1fr;gap:28px}}
.page-template-page-about .ph-title{font-size:clamp(38px,5vw,72px);line-height:1.02;letter-spacing:-.022em}
.page-template-page-about .ph-desc{font-size:17px;line-height:1.6;color:var(--muted);max-width:50ch;margin-bottom:24px}
.page-template-page-about .ph-stats{display:flex;gap:40px;padding-top:20px;border-top:1px solid var(--rule);flex-wrap:wrap}
.page-template-page-about .ph-stat{padding:0;border-right:none}
.page-template-page-about .ph-stat .n{font-size:36px;font-weight:300;letter-spacing:-.02em}
.page-template-page-about .ph-stat .l{font-size:10px;margin-top:6px}

/* mission & vision */
.mv-section{background:var(--paper-warm);padding:80px 0;border-bottom:1px solid var(--rule)}
.mv-grid{display:grid;grid-template-columns:1fr 1px 1fr;gap:0;align-items:start}
@media(max-width:780px){.mv-grid{grid-template-columns:1fr;gap:48px}}
.mv-block{padding:0 48px}
.mv-block:first-child{padding-left:0}
.mv-block:last-child{padding-right:0}
@media(max-width:780px){.mv-block,.mv-block:first-child,.mv-block:last-child{padding:0}}
.mv-divider{background:var(--rule-strong);height:100%;min-height:200px}
@media(max-width:780px){.mv-divider{display:none}}
.mv-label{font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.mv-label::before{content:'';display:block;width:24px;height:1px;background:var(--brass)}
.mv-text{font-family:var(--serif);font-size:clamp(17px,2vw,21px);line-height:1.65;color:var(--ink);font-style:italic;font-weight:300;text-wrap:pretty}

/* light image placeholder (for story / team photos on white bg) */
.img-placeholder-light{background:var(--paper-3);border:1px dashed var(--rule-strong);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;text-align:center}
.img-placeholder-light::before{content:'';width:36px;height:36px;border-radius:50%;border:2px dashed var(--rule-strong);display:block}

/* our story */
.story-section{padding:88px 0;border-bottom:1px solid var(--rule)}
.story-photo{margin-bottom:56px}
.story-photo-ph{width:100%;aspect-ratio:16/6}
.story-photo-caption{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:12px}
.story-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
@media(max-width:860px){.story-grid{grid-template-columns:1fr;gap:36px}}
.story-title{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.5vw,46px);line-height:1.08;letter-spacing:-.02em;margin-top:8px;text-wrap:balance}
.story-title em{font-style:italic;color:var(--brass-deep)}
.story-body{font-size:16px;line-height:1.75;color:#334455;text-wrap:pretty;margin-bottom:20px}
.story-body:last-child{margin-bottom:0}
.story-credential{display:flex;align-items:center;gap:16px;margin-top:36px;padding-top:28px;border-top:1px solid var(--rule)}
.cred-mark{flex:0 0 40px;height:40px;border-radius:50%;border:1.5px solid var(--ink);display:grid;place-items:center;font-family:var(--serif);font-weight:500;font-size:14px;color:var(--ink);overflow:hidden}
.cred-logo-img{width:100%;height:100%;object-fit:contain;padding:5px}
.cred-mark-fallback::before{content:'PK';font-family:var(--serif);font-weight:500;font-size:14px;color:var(--ink)}
.cred-line{display:flex;flex-direction:column;gap:4px}
.cred-name{font-family:var(--serif);font-size:18px;font-weight:400}
.cred-title-text{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* values */
.values-section{background:var(--ink-deep);padding:88px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.values-header{margin-bottom:56px}
.values-header .section-eyebrow{color:rgba(255,255,255,.4)}
.values-header .section-eyebrow .eline{background:rgba(255,255,255,.18)}
.values-header .idx{color:var(--brass)}
.values-title{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3.5vw,44px);color:#fff;letter-spacing:-.018em;line-height:1.1}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.12)}
@media(max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.values-grid{grid-template-columns:1fr}}
.value-card{padding:36px 32px 40px;border-right:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
.value-card:last-child{border-right:none}
@media(max-width:900px){.value-card:nth-child(2){border-right:none}.value-card:nth-child(3){border-right:none}}
@media(max-width:540px){.value-card{border-right:none}}
.val-num{font-family:var(--mono);font-size:13px;letter-spacing:.12em;color:var(--brass);margin-bottom:20px}
.val-name{font-family:var(--serif);font-size:22px;font-weight:400;color:#fff;margin-bottom:14px;line-height:1.15}
.val-desc{font-size:14px;line-height:1.7;color:rgba(255,255,255,.58);text-wrap:pretty}

/* ═══════════════════════════════════════════════════════════
   Blog / News page
   ═══════════════════════════════════════════════════════════ */

/* hero overrides */
.page-template-page-blog .page-hero{padding:56px 0 52px}
.page-template-page-blog .ph-grid{grid-template-columns:1fr 1fr;gap:64px;align-items:end;border-top:none}
@media(max-width:780px){.page-template-page-blog .ph-grid{grid-template-columns:1fr;gap:24px}}
.page-template-page-blog .ph-title{font-size:clamp(38px,5vw,68px);line-height:1.02;letter-spacing:-.022em}
.page-template-page-blog .ph-desc{font-family:var(--serif);font-size:17px;line-height:1.55;color:var(--muted);max-width:50ch}

/* blog main container */
.blog-main{max-width:1320px;margin:0 auto;padding:48px 40px 80px}
@media(max-width:600px){.blog-main{padding:32px 22px 60px}}

/* active filter label */
.blog-filter-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--rule);color:var(--muted)}
.blog-filter-label span{color:var(--brass-deep)}

/* post meta row */
.post-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.post-cat{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.post-date{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.post-read-time{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.meta-dot{width:3px;height:3px;border-radius:50%;background:var(--rule-strong);flex:0 0 auto}
.post-author{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* category colour accents */
.cat-company{color:#144888}
.cat-shipyard{color:#2e7d52}
.cat-docking{color:#7b4400}
.cat-equipment{color:#5b2a8a}
.cat-misc{color:#6a4a20}

/* read link */
.read-link{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:6px;transition:color .18s}
.read-link .arr{transition:transform .2s}

/* featured post */
.featured-post{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--rule);margin-bottom:40px;transition:all .22s;color:inherit;text-decoration:none}
.featured-post:hover{border-color:var(--ink);box-shadow:0 12px 40px -16px rgba(20,72,136,.18)}
@media(max-width:860px){.featured-post{grid-template-columns:1fr}}
.fp-img{overflow:hidden;background:var(--paper-2);position:relative;min-height:380px}
@media(max-width:860px){.fp-img{min-height:240px}}
.fp-img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0}
.fp-img .img-placeholder-light{position:absolute;inset:0;height:100%}
.fp-featured-badge{position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;background:var(--ink);color:var(--paper);padding:5px 11px;z-index:2}
.fp-body{padding:40px 40px 36px;display:flex;flex-direction:column;gap:16px;background:var(--paper)}
@media(max-width:600px){.fp-body{padding:28px 24px}}
.fp-title{font-family:var(--serif);font-size:clamp(22px,2.8vw,34px);font-weight:400;line-height:1.12;letter-spacing:-.018em;text-wrap:balance}
.fp-excerpt{font-size:15px;line-height:1.72;color:#334455;text-wrap:pretty;flex:1}
.fp-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--rule);margin-top:auto}
.featured-post:hover .read-link{color:var(--brass-deep)}
.featured-post:hover .arr{transform:translateX(4px)}

/* posts grid — 3 columns */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
@media(max-width:960px){.posts-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.posts-grid{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column;transition:all .22s;background:var(--paper);color:inherit;text-decoration:none}
.post-card:hover{background:var(--paper-2)}
.post-card:hover .read-link{color:var(--brass-deep)}
.post-card:hover .arr{transform:translateX(4px)}
.pc-img{overflow:hidden;background:var(--paper-2);aspect-ratio:16/9;position:relative}
.pc-img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0}
.pc-img .img-placeholder-light{position:absolute;inset:0;height:100%;aspect-ratio:unset}
.pc-body{padding:24px 24px 22px;flex:1;display:flex;flex-direction:column;gap:12px}
.pc-title{font-family:var(--serif);font-size:clamp(17px,2vw,21px);font-weight:400;line-height:1.18;letter-spacing:-.012em;text-wrap:balance}
.pc-excerpt{font-size:13.5px;line-height:1.7;color:#445566;text-wrap:pretty;flex:1}
.pc-footer{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--rule);margin-top:auto}

/* empty state (blog-specific, distinct from shipyards .empty-state) */
.blog-empty{display:none;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center;gap:16px}
.blog-empty.visible{display:flex}
.blog-empty .be-icon{width:56px;height:56px;border:1px solid var(--rule);border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-size:22px;color:var(--muted)}
.blog-empty .be-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--ink)}
.blog-empty .be-sub{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* newsletter strip */
.newsletter-section{background:var(--paper-warm);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:56px 0}
.nl-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:780px){.nl-grid{grid-template-columns:1fr;gap:28px}}
.nl-title{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3vw,36px);letter-spacing:-.018em;line-height:1.1;margin-bottom:10px}
.nl-title em{font-style:italic;color:var(--brass-deep)}
.nl-desc{font-size:15px;line-height:1.65;color:var(--muted);max-width:46ch;text-wrap:pretty}
.nl-form{display:flex;gap:10px;flex-wrap:wrap}
.nl-input{flex:1 1 220px;padding:12px 16px;border:1px solid var(--rule-strong);font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--paper);outline:none;transition:border-color .2s;min-width:0}
.nl-input:focus{border-color:var(--ink)}
.nl-input::placeholder{color:var(--muted)}
.nl-btn{padding:12px 24px;background:var(--ink);color:var(--paper);font-family:var(--sans);font-size:13px;font-weight:500;border:none;cursor:pointer;white-space:nowrap;transition:background .2s;flex:0 0 auto}
.nl-btn:hover{background:var(--ink-deep)}
.nl-note{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:10px}

/* ═══════════════════════════════════════════════════════════
   Single post (article)
   ═══════════════════════════════════════════════════════════ */

/* post breadcrumb */
.post-breadcrumb{padding:18px 0;border-bottom:1px solid var(--rule)}
.post-breadcrumb .wrap{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.post-breadcrumb a:hover{color:var(--ink)}
.bc-sep{opacity:.4}

/* article header */
.article-header{padding:52px 0 0;text-align:center}
.ah-inner{max-width:700px;margin:0 auto;padding:0 24px}
.ah-eyebrow{display:flex;align-items:center;justify-content:center;gap:14px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:28px}
.ah-eyebrow .eline{flex:0 0 40px;height:1px;background:var(--rule-strong)}
.ah-cat{font-weight:500}
.article-title{font-family:var(--serif);font-weight:400;font-size:clamp(30px,5vw,54px);line-height:1.06;letter-spacing:-.024em;text-wrap:balance;margin-bottom:24px}
.article-standfirst{font-family:var(--serif);font-style:italic;font-size:clamp(17px,2.2vw,21px);line-height:1.52;color:var(--muted);text-wrap:pretty;max-width:58ch;margin:0 auto 32px}
.article-meta{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid var(--rule)}
.am-author{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.am-dot{width:3px;height:3px;border-radius:50%;background:var(--rule-strong)}
.am-date{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.am-read{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* hero image */
.post-hero-image{max-width:1020px;margin:0 auto;padding:0 40px}
@media(max-width:600px){.post-hero-image{padding:0}}
.post-hero-image img{width:100%;display:block;aspect-ratio:16/7;object-fit:cover}
.post-hero-image .img-placeholder-light{width:100%;aspect-ratio:16/7}

/* article body */
.article-body{max-width:700px;margin:0 auto;padding:48px 24px 64px}
.article-body > p{font-family:var(--serif);font-size:18px;line-height:1.72;color:#1a2a3a;margin-bottom:1.5em;text-wrap:pretty}
.article-body > p:first-child{font-size:20px;line-height:1.68;font-weight:400;color:var(--ink)}
.article-body h2{font-family:var(--serif);font-size:clamp(20px,2.4vw,28px);font-weight:400;letter-spacing:-.016em;line-height:1.14;margin:2em 0 .75em}
.article-body h3{font-family:var(--serif);font-size:19px;font-weight:500;margin:1.6em 0 .5em}
.article-body strong{font-weight:600}
.article-body ul,.article-body ol{padding-left:1.4em;margin-bottom:1.5em;display:flex;flex-direction:column;gap:8px}
.article-body li{font-family:var(--serif);font-size:18px;line-height:1.65;color:#1a2a3a}
.article-body a{color:var(--ink-2);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.article-body a:hover{color:var(--brass-deep)}

/* feature list — breaks outside the 700px text column */
.feature-list{margin:2.5em -40px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
@media(max-width:780px){.feature-list{margin:2em 0}}
.feature-list-inner{display:grid;grid-template-columns:1fr 1fr;gap:0}
@media(max-width:640px){.feature-list-inner{grid-template-columns:1fr}}
.feature-item{display:flex;gap:20px;padding:28px 32px;border-bottom:1px solid var(--rule);border-right:1px solid var(--rule)}
.feature-item:nth-child(2n){border-right:none}
.feature-item:nth-last-child(-n+2){border-bottom:none}
.feature-item.full{grid-column:1/-1;border-right:none;border-bottom:none}
@media(max-width:640px){.feature-item{border-right:none}.feature-item:nth-last-child(1){border-bottom:none}.feature-item:nth-last-child(2){border-bottom:1px solid var(--rule)}.feature-item.full{border-bottom:none}}
.fi-num{flex:0 0 auto;font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--brass-deep);padding-top:3px;min-width:22px}
.fi-heading{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px;letter-spacing:-.01em}
.fi-desc{font-family:var(--sans);font-size:13.5px;line-height:1.62;color:#445566}

/* closing callout */
.closing-callout{background:var(--ink);color:var(--paper);padding:32px 36px;margin:2.5em 0;position:relative;overflow:hidden}
.closing-callout::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.04)}
.cc-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:14px}
.cc-text{font-family:var(--serif);font-style:italic;font-size:clamp(17px,2.2vw,22px);line-height:1.48;color:var(--paper);margin-bottom:0}

/* article footer */
.article-footer{max-width:700px;margin:0 auto;padding:0 24px 64px}
.af-divider{height:1px;background:var(--rule);margin-bottom:28px}
.af-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.af-back{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);transition:color .18s}
.af-back:hover{color:var(--ink)}
.af-back .arr{transition:transform .2s}
.af-back:hover .arr{transform:translateX(-4px)}
.af-share{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* related posts strip */
.more-posts{border-top:1px solid var(--rule);padding:56px 0}
.mp-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:12px}
.mp-title{font-family:var(--serif);font-size:clamp(18px,2.4vw,26px);font-weight:400;letter-spacing:-.012em}
.mp-all{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:color .18s}
.mp-all:hover{color:var(--ink)}
.mp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:860px){.mp-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.mp-grid{grid-template-columns:1fr}}
.mp-card{display:flex;flex-direction:column;border:1px solid var(--rule);transition:all .2s;color:inherit;text-decoration:none}
.mp-card:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:0 8px 24px -12px rgba(20,72,136,.18)}
.mp-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--paper-2);position:relative}
.mp-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.mp-card-img .img-placeholder-light{position:absolute;inset:0;height:100%;aspect-ratio:unset}
.mp-card-body{padding:18px 20px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.mp-card-cat{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase}
.mp-card-title{font-family:var(--serif);font-size:16px;font-weight:400;line-height:1.22;letter-spacing:-.01em;text-wrap:balance;flex:1}
.mp-card-meta{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
