/* ==============================================================
   IIC WEBSITE — VISUAL LANGUAGE
   Fonts: Space Grotesk (display) + IBM Plex Sans (body) + IBM Plex Mono (codes)
   Palette: Blue primary, Mist backgrounds, minimal accent red
   Style: Magazine asymmetric, angular frames, sentence case
   ============================================================== */

:root {
  --font-display: 'Space Grotesk', sans-serif;
  --font-body:    'IBM Plex Sans', sans-serif;
  --font-mono:    'IBM Plex Mono', monospace;
  --iic-radius:   4px;
  --iic-radius-lg: 14px;
}

/* ==============================================================
   RESETS
   ============================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}
body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--iic-ink);
  background: #fff;
  overflow-x: hidden;
  max-width: 100%;
  font-weight: 400;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--iic-primary); text-decoration: none; }
a, button, input, select, textarea { touch-action: manipulation; }

.iic-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
}

/* ==============================================================
   TYPOGRAPHY SYSTEM — sentence case (NOT uppercase)
   ============================================================== */
.iic-h2 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4.5vw, 48px);
  font-weight: 500;
  color: var(--iic-ink);
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: 14px;
}
.iic-h2-light { color: #fff; }
.iic-h3 {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.5vw, 26px);
  font-weight: 500;
  color: var(--iic-ink);
  line-height: 1.2;
  margin-bottom: 14px;
}
.iic-lead {
  font-size: clamp(15px, 1.6vw, 17px);
  color: var(--iic-ink-soft);
  line-height: 1.75;
  margin-bottom: 16px;
}

.iic-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--iic-primary-dk);
  letter-spacing: 2px;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.iic-eyebrow-light { color: var(--iic-primary-lt); }
.iic-eyebrow-dot {
  display: inline-block;
  width: 8px; height: 8px;
  background: var(--iic-primary);
  border-radius: 50%;
}

.iic-section-head {
  padding: 0 clamp(12px, 3vw, 28px);
  max-width: 1280px;
  margin: 0 auto clamp(40px, 6vw, 72px);
}
.iic-section-lead {
  color: var(--iic-ink-soft);
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 1.65;
  max-width: 680px;
  margin-top: 10px;
}

/* ==============================================================
   LOGO MARK — reproduction of IIC logo (I + arc-C)
   ============================================================== */
.iic-logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  color: var(--iic-ink);
  letter-spacing: -0.5px;
  position: relative;
  padding-right: 2px;
}
.iic-logo-mark-lg { font-size: 40px; }
.iic-logo-arc {
  display: inline-block;
  width: 8px; height: 14px;
  border: 2.5px solid var(--iic-accent);
  border-left: none;
  border-radius: 0 50% 50% 0 / 0 100% 100% 0;
  margin: 0 1px;
  position: relative;
  top: 1px;
}
.iic-logo-mark-lg .iic-logo-arc { width: 14px; height: 26px; border-width: 4px; top: 2px; }

/* ==============================================================
   NAVBAR — light background, different from EPCM's dark navbar
   ============================================================== */
.iic-navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--iic-line);
  width: 100%;
}
.iic-nav-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  height: clamp(60px, 8vw, 72px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.iic-nav-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  min-height: 44px;
}
.iic-logo-text {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  color: var(--iic-ink);
  letter-spacing: 0.2px;
  display: none;
}
.iic-logo-text-short {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--iic-ink);
  letter-spacing: 1px;
}
@media (min-width: 900px) {
  .iic-logo-text { display: inline; }
  .iic-logo-text-short { display: none; }
}
.iic-nav-links {
  display: none;
  align-items: center;
  gap: 4px;
}
@media (min-width: 900px) {
  .iic-nav-links { display: flex; }
}
.iic-nav-links a {
  color: var(--iic-ink-soft);
  text-decoration: none;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  padding: 10px 16px;
  border-radius: var(--iic-radius);
  min-height: 44px;
  display: flex;
  align-items: center;
  transition: color .2s, background .2s;
}
.iic-nav-links a:hover { color: var(--iic-primary); background: var(--iic-mist); }
.iic-nav-cta {
  background: var(--iic-ink) !important;
  color: #fff !important;
  padding: 10px 20px !important;
  font-weight: 500 !important;
}
.iic-nav-cta:hover { background: var(--iic-primary-dk) !important; color: #fff !important; }

.iic-nav-toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px; height: 44px;
  background: none;
  border: 1px solid var(--iic-line);
  border-radius: var(--iic-radius);
  cursor: pointer;
  padding: 0;
}
.iic-nav-toggle span {
  display: block;
  width: 18px; height: 2px;
  background: var(--iic-ink);
  transition: transform .25s;
}
@media (min-width: 900px) {
  .iic-nav-toggle { display: none; }
}

/* ==============================================================
   ANGULAR FRAME — signature IIC decoration (from PDF)
   ============================================================== */
.iic-angular-frame {
  position: absolute;
  top: 0; bottom: 0;
  left: 0;
  width: clamp(30px, 5vw, 70px);
  pointer-events: none;
  z-index: 1;
}
.iic-angular-frame.iic-frame-right {
  left: auto;
  right: 0;
  transform: scaleX(-1);
}
.iic-angular-frame svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ==============================================================
   HERO — SPLIT-SCREEN (text left, service panel right)
   Completely different from EPCM's full-dark-screen-with-stats
   ============================================================== */
.iic-hero {
  position: relative;
  background: var(--iic-mist);
  padding: clamp(90px, 14vw, 130px) 0 clamp(40px, 6vw, 60px);
  overflow: hidden;
}
.iic-hero-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(32px, 5vw, 56px);
  align-items: center;
  position: relative;
  z-index: 2;
}
@media (min-width: 900px) {
  .iic-hero-grid { grid-template-columns: 1.05fr 1fr; }
}

.iic-hero-title {
  font-family: var(--font-display);
  font-size: clamp(34px, 6vw, 64px);
  font-weight: 500;
  color: var(--iic-ink);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin-bottom: 20px;
}
.iic-hero-lead {
  font-size: clamp(15px, 1.7vw, 18px);
  color: var(--iic-ink-soft);
  line-height: 1.7;
  margin-bottom: 28px;
  max-width: 560px;
}
.iic-hero-emph {
  color: var(--iic-ink);
  font-weight: 500;
  background: linear-gradient(180deg, transparent 60%, rgba(43, 127, 191, 0.15) 60%);
  padding: 0 3px;
}

.iic-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}
.iic-btn-solid {
  background: var(--iic-ink);
  color: #fff;
  padding: 14px 24px;
  border-radius: var(--iic-radius);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.3px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  min-height: 48px;
  transition: background .2s, transform .2s;
  border: none;
  cursor: pointer;
}
.iic-btn-solid:hover { background: var(--iic-primary-dk); transform: translateY(-1px); }
.iic-btn-solid i { font-size: 11px; transition: transform .2s; }
.iic-btn-solid:hover i { transform: translateX(3px); }

.iic-btn-ghost {
  background: transparent;
  color: var(--iic-ink);
  padding: 14px 24px;
  border: 1px solid var(--iic-line);
  border-radius: var(--iic-radius);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.3px;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  min-height: 48px;
  transition: border-color .2s, background .2s;
}
.iic-btn-ghost:hover { border-color: var(--iic-primary); background: rgba(43, 127, 191, 0.04); }

/* Code chips — small, technical, monospace */
.iic-hero-codes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.iic-code-chip {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--iic-primary-dk);
  background: #fff;
  border: 1px solid var(--iic-line);
  padding: 5px 10px;
  border-radius: 3px;
}

/* RIGHT SIDE — glass panel with service catalog */
.iic-hero-right { position: relative; }
.iic-hero-visual {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  filter: grayscale(15%);
}
.iic-hero-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(43, 127, 191, 0.3) 0%, rgba(15, 23, 36, 0.7) 100%);
  border-radius: var(--iic-radius-lg);
}
.iic-hero-panel {
  position: relative;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(8px);
  border-radius: var(--iic-radius-lg);
  padding: clamp(20px, 3vw, 28px);
  box-shadow: 0 10px 40px rgba(30, 58, 95, 0.08);
  border: 1px solid rgba(43, 127, 191, 0.08);
  margin: clamp(20px, 3vw, 32px);
}
.iic-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--iic-line);
  margin-bottom: 8px;
}
.iic-panel-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--iic-steel);
  font-weight: 500;
}
.iic-panel-counter {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--iic-primary);
  font-weight: 500;
}
.iic-panel-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.iic-panel-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 2px;
  border-bottom: 1px solid rgba(216, 224, 234, 0.5);
  cursor: pointer;
  transition: padding .2s, color .2s;
}
.iic-panel-list li:last-child { border-bottom: none; }
.iic-panel-list li:hover { padding-left: 6px; color: var(--iic-primary); }
.iic-panel-list li.active { color: var(--iic-primary); }
.iic-panel-list li.active .iic-panel-num { background: var(--iic-primary); color: #fff; }
.iic-panel-num {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  width: 28px; height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--iic-mist);
  color: var(--iic-steel);
  border-radius: 3px;
  flex-shrink: 0;
  transition: background .2s, color .2s;
}
.iic-panel-title {
  flex: 1;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--iic-ink);
}
.iic-panel-list li i {
  color: var(--iic-steel);
  font-size: 11px;
  transition: transform .2s, color .2s;
}
.iic-panel-list li:hover i { transform: translateX(3px); color: var(--iic-primary); }

.iic-hero-strip {
  max-width: 1280px;
  margin: clamp(40px, 6vw, 72px) auto 0;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--iic-line);
  border: 1px solid var(--iic-line);
  border-radius: var(--iic-radius);
  overflow: hidden;
}
@media (min-width: 640px) {
  .iic-hero-strip { grid-template-columns: repeat(4, 1fr); }
}
.iic-metric {
  background: #fff;
  padding: clamp(18px, 2.5vw, 28px);
  text-align: center;
}
.iic-metric-n {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.8vw, 32px);
  font-weight: 500;
  color: var(--iic-ink);
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 4px;
}
.iic-metric-l {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--iic-steel);
  text-transform: uppercase;
}

/* ==============================================================
   ABOUT
   ============================================================== */
.iic-about {
  padding: clamp(56px, 9vw, 110px) 0;
  background: #fff;
  position: relative;
}
.iic-about-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(32px, 5vw, 60px);
}
@media (min-width: 900px) {
  .iic-about-grid { grid-template-columns: 1.2fr 1fr; }
}
.iic-about-text p {
  color: var(--iic-ink-soft);
  line-height: 1.75;
  margin-bottom: 14px;
  font-size: clamp(14px, 1.5vw, 15px);
}
.iic-about-text strong { color: var(--iic-ink); font-weight: 500; }

.iic-about-reg {
  margin-top: 28px;
  background: var(--iic-mist);
  border-radius: var(--iic-radius);
  padding: 20px 22px;
  border-left: 3px solid var(--iic-primary);
}
.iic-reg-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 8px 0;
  font-size: 13px;
  flex-wrap: wrap;
}
.iic-reg-row:not(:last-child) { border-bottom: 1px solid var(--iic-line); }
.iic-reg-label {
  font-family: var(--font-mono);
  color: var(--iic-steel);
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: 11px;
  min-width: 140px;
}
.iic-reg-value {
  color: var(--iic-ink);
  font-weight: 500;
  text-align: right;
  flex: 1;
}

.iic-about-side {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.iic-about-img {
  width: 100%;
  height: clamp(200px, 28vw, 300px);
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  filter: grayscale(10%);
}
.iic-img-empty {
  background: var(--iic-mist);
  border: 2px dashed var(--iic-line);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--iic-line);
  font-size: 48px;
}

.iic-heritage-card {
  background: var(--iic-ink);
  color: #fff;
  border-radius: var(--iic-radius-lg);
  padding: 22px;
}
.iic-heritage-title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 6px;
}
.iic-heritage-sub {
  color: rgba(255,255,255,0.55);
  font-size: 13px;
  margin-bottom: 14px;
}
.iic-heritage-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.iic-heritage-chips span {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.5px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.85);
  padding: 5px 10px;
  border-radius: 3px;
}

/* ==============================================================
   MANPOWER
   ============================================================== */
.iic-manpower {
  padding: clamp(56px, 9vw, 110px) 0;
  background: var(--iic-mist);
  position: relative;
  overflow: hidden;
}
.iic-manpower-layout {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4vw, 48px);
  align-items: flex-start;
}
@media (min-width: 900px) {
  .iic-manpower-layout { grid-template-columns: 0.85fr 1.15fr; }
}
.iic-manpower-visual {
  width: 100%;
  height: clamp(260px, 40vw, 440px);
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  position: sticky;
  top: 90px;
  filter: grayscale(15%);
}

.iic-disciplines {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.iic-discipline {
  background: #fff;
  border: 1px solid var(--iic-line);
  border-radius: var(--iic-radius-lg);
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.iic-discipline[open] {
  border-color: var(--iic-primary);
  box-shadow: 0 4px 18px rgba(43, 127, 191, 0.08);
}
.iic-discipline summary {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  cursor: pointer;
  list-style: none;
  min-height: 64px;
}
.iic-discipline summary::-webkit-details-marker { display: none; }
.iic-disc-num {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--iic-primary);
  width: 32px;
  flex-shrink: 0;
}
.iic-disc-ico {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--iic-mist);
  color: var(--iic-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
.iic-disc-title {
  flex: 1;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--iic-ink);
}
.iic-disc-count {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.5px;
  color: var(--iic-steel);
  background: var(--iic-mist);
  padding: 4px 10px;
  border-radius: 3px;
}
.iic-disc-toggle {
  color: var(--iic-primary);
  font-size: 13px;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--iic-mist);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .25s;
}
.iic-discipline[open] .iic-disc-toggle { transform: rotate(45deg); }
.iic-disc-body {
  padding: 0 22px 22px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 640px) {
  .iic-disc-body { grid-template-columns: 1fr 1fr; gap: 14px; }
}
.iic-role {
  padding: 12px 14px;
  background: var(--iic-mist);
  border-radius: var(--iic-radius);
  border-left: 2px solid var(--iic-primary-lt);
}
.iic-role-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  color: var(--iic-ink);
  margin-bottom: 2px;
}
.iic-role-desc {
  font-size: 13px;
  color: var(--iic-ink-soft);
  line-height: 1.55;
}

/* ==============================================================
   MAINTENANCE
   ============================================================== */
.iic-maintenance {
  padding: clamp(56px, 9vw, 110px) 0;
  background: #fff;
}
.iic-maint-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(24px, 3vw, 32px);
}
@media (min-width: 900px) {
  .iic-maint-grid {
    grid-template-columns: 1fr 1.1fr;
    grid-template-areas:
      "services visual"
      "engineered engineered";
    gap: 32px 40px;
  }
  .iic-maint-services   { grid-area: services; }
  .iic-maint-visual     { grid-area: visual; }
  .iic-maint-engineered { grid-area: engineered; margin-top: 24px; }
}

.iic-maint-group-title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  color: var(--iic-ink);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--iic-primary);
  display: inline-block;
}
.iic-maint-list {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
}
@media (min-width: 500px) {
  .iic-maint-list { grid-template-columns: 1fr 1fr; }
}
.iic-maint-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  font-size: 13.5px;
  color: var(--iic-ink);
  border-bottom: 1px solid var(--iic-line);
  min-height: 48px;
}
.iic-maint-list li i {
  color: var(--iic-primary);
  font-size: 13px;
  width: 18px;
  text-align: center;
  flex-shrink: 0;
}

.iic-maint-visual {
  width: 100%;
  min-height: 280px;
  height: 100%;
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  filter: grayscale(10%);
}

.iic-engineered-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px)  { .iic-engineered-cards { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .iic-engineered-cards { grid-template-columns: repeat(4, 1fr); } }
.iic-eng-card {
  padding: 22px 20px;
  background: var(--iic-mist);
  border-radius: var(--iic-radius-lg);
  border-top: 3px solid var(--iic-primary);
  transition: transform .25s, background .25s;
}
.iic-eng-card:hover {
  background: #fff;
  border-color: var(--iic-primary-dk);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(43, 127, 191, 0.1);
}
.iic-eng-icon {
  width: 42px; height: 42px;
  border-radius: var(--iic-radius);
  background: #fff;
  color: var(--iic-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  margin-bottom: 14px;
  border: 1px solid var(--iic-line);
}
.iic-eng-card h4 {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--iic-ink);
  margin-bottom: 6px;
}
.iic-eng-card p {
  font-size: 13px;
  color: var(--iic-ink-soft);
  line-height: 1.55;
}

/* ==============================================================
   PROJECT EXECUTION
   ============================================================== */
.iic-project-exec {
  padding: clamp(56px, 9vw, 110px) 0;
  background: var(--iic-mist);
}
.iic-pex-layout {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4vw, 48px);
}
@media (min-width: 900px) {
  .iic-pex-layout { grid-template-columns: 1.1fr 1fr; }
}
.iic-pex-list {
  list-style: none;
  padding: 0;
  background: #fff;
  border-radius: var(--iic-radius-lg);
  overflow: hidden;
  border: 1px solid var(--iic-line);
}
.iic-pex-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--iic-line);
  font-size: 13.5px;
  color: var(--iic-ink);
  line-height: 1.55;
}
.iic-pex-list li:last-child { border-bottom: none; }
.iic-pex-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 1px;
  color: var(--iic-primary-dk);
  background: var(--iic-mist);
  padding: 4px 8px;
  border-radius: 3px;
  flex-shrink: 0;
  min-width: 110px;
  text-align: center;
  line-height: 1.4;
}
.iic-pex-visual {
  position: relative;
  width: 100%;
  min-height: 380px;
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  overflow: hidden;
}
.iic-pex-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15, 23, 36, 0.3) 0%, rgba(15, 23, 36, 0.9) 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 26px;
  color: #fff;
}
.iic-pex-overlay-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--iic-primary-lt);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.iic-pex-overlay-title {
  font-family: var(--font-display);
  font-size: clamp(17px, 2.2vw, 22px);
  font-weight: 500;
  line-height: 1.3;
  margin-bottom: 16px;
}
.iic-pex-fat-sat {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.iic-pex-fat-sat span {
  font-family: var(--font-mono);
  font-size: 11px;
  color: #fff;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  padding: 5px 10px;
  border-radius: 3px;
}

/* ==============================================================
   ASSET INTEGRITY — HEXAGON DIAGRAM
   ============================================================== */
.iic-integrity {
  padding: clamp(56px, 9vw, 110px) 0;
  background: #fff;
}
.iic-aim-layout {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(32px, 5vw, 56px);
  align-items: center;
}
@media (min-width: 900px) {
  .iic-aim-layout { grid-template-columns: 1fr 1fr; }
}
.iic-hexagon-wrap {
  position: relative;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}
.iic-hex-svg {
  width: 100%;
  height: auto;
}
.iic-hex-node {
  transition: transform .25s;
  transform-origin: center;
  cursor: pointer;
}
.iic-hex-node:hover { transform: scale(1.05); }

.iic-aim-list {
  list-style: none;
  padding: 0;
}
.iic-aim-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--iic-line);
  font-size: 14px;
  color: var(--iic-ink-soft);
  line-height: 1.55;
}
.iic-aim-list li:last-child { border-bottom: none; }
.iic-aim-list strong { color: var(--iic-ink); font-weight: 500; }
.iic-aim-bullet {
  flex-shrink: 0;
  width: 10px; height: 10px;
  background: var(--iic-primary);
  margin-top: 7px;
  transform: rotate(45deg);
}

/* ==============================================================
   INSPECTION & EXPERTISE
   ============================================================== */
.iic-inspection {
  padding: clamp(56px, 9vw, 110px) 0;
  background: var(--iic-mist);
}
.iic-insp-layout {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4vw, 48px);
}
@media (min-width: 900px) {
  .iic-insp-layout { grid-template-columns: 1fr 1.3fr; }
}
.iic-insp-visual {
  width: 100%;
  min-height: 360px;
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  filter: grayscale(15%);
}

.iic-insp-principles {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 32px;
}
.iic-principle {
  display: flex;
  gap: 16px;
  padding: 18px;
  background: #fff;
  border-radius: var(--iic-radius-lg);
  border: 1px solid var(--iic-line);
}
.iic-principle-sym {
  font-size: 20px;
  color: var(--iic-primary);
  width: 36px;
  text-align: center;
  flex-shrink: 0;
}
.iic-principle h4 {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  color: var(--iic-ink);
  margin-bottom: 4px;
}
.iic-principle p {
  font-size: 13px;
  color: var(--iic-ink-soft);
  line-height: 1.5;
}

.iic-insp-codes, .iic-insp-domains { margin-bottom: 24px; }
.iic-codes-label, .iic-domains-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--iic-steel);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.iic-codes-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.iic-codes-grid span {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--iic-primary-dk);
  background: #fff;
  border: 1px solid var(--iic-line);
  padding: 6px 12px;
  border-radius: 3px;
}
.iic-insp-domains p {
  font-size: 13.5px;
  color: var(--iic-ink-soft);
  line-height: 1.75;
}

/* ==============================================================
   NDT SERVICES EXPLORER — TABBED
   ============================================================== */
.iic-ndt {
  padding: clamp(56px, 9vw, 110px) 0;
  background: var(--iic-ink);
  color: #fff;
}
.iic-ndt .iic-h2 { color: #fff; }
.iic-ndt .iic-eyebrow { color: var(--iic-primary-lt); }
.iic-ndt .iic-section-lead { color: rgba(255,255,255,0.6); }

.iic-ndt-explorer {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
}
.iic-ndt-tabs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-bottom: 24px;
}
@media (min-width: 640px) {
  .iic-ndt-tabs { grid-template-columns: repeat(3, 1fr); }
}
.iic-ndt-tab {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  padding: 20px 22px;
  border-radius: var(--iic-radius-lg);
  text-align: left;
  cursor: pointer;
  font-family: var(--font-body);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  transition: background .2s, border-color .2s;
}
.iic-ndt-tab:hover { background: rgba(255,255,255,0.07); border-color: var(--iic-primary-lt); }
.iic-ndt-tab.active {
  background: var(--iic-primary);
  border-color: var(--iic-primary);
}
.iic-tab-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--iic-primary-lt);
  margin-bottom: 4px;
}
.iic-ndt-tab.active .iic-tab-num { color: rgba(255,255,255,0.65); }
.iic-tab-label {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 500;
  color: #fff;
}
.iic-tab-count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(255,255,255,0.5);
  margin-top: 2px;
}

.iic-ndt-panel {
  display: none;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--iic-radius-lg);
  overflow: hidden;
}
.iic-ndt-panel.active { display: block; }
.iic-ndt-panel-grid {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 360px;
}
@media (min-width: 900px) {
  .iic-ndt-panel-grid { grid-template-columns: 1fr 1.3fr; }
}
.iic-ndt-panel-img {
  background-size: cover;
  background-position: center;
  min-height: 240px;
  filter: grayscale(20%);
}
.iic-ndt-panel-body {
  padding: clamp(24px, 4vw, 40px);
}
.iic-method {
  display: flex;
  gap: 18px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.iic-method:last-child { border-bottom: none; }
.iic-method-code {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 1px;
  color: var(--iic-primary-lt);
  background: rgba(43, 127, 191, 0.12);
  border: 1px solid rgba(74, 159, 223, 0.3);
  padding: 6px 10px;
  border-radius: 3px;
  height: fit-content;
  min-width: 60px;
  text-align: center;
  flex-shrink: 0;
}
.iic-method-info h4 {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  margin-bottom: 4px;
}
.iic-method-info p {
  font-size: 13.5px;
  color: rgba(255,255,255,0.65);
  line-height: 1.6;
}

.iic-adv-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 500px) { .iic-adv-grid { grid-template-columns: 1fr 1fr; } }
.iic-adv {
  padding: 14px;
  background: rgba(255,255,255,0.04);
  border-left: 2px solid var(--iic-primary);
  border-radius: 3px;
}
.iic-adv-code {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--iic-primary-lt);
  margin-bottom: 4px;
}
.iic-adv-title {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  margin-bottom: 4px;
}
.iic-adv-desc {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  line-height: 1.5;
}

/* ==============================================================
   TRAINING
   ============================================================== */
.iic-training {
  padding: clamp(56px, 9vw, 110px) 0;
  background: #fff;
}
.iic-training-layout {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4vw, 40px);
  align-items: flex-start;
}
@media (min-width: 900px) {
  .iic-training-layout { grid-template-columns: 0.8fr 1.2fr; }
}
.iic-training-visual {
  position: relative;
  width: 100%;
  min-height: 380px;
  background-size: cover;
  background-position: center;
  border-radius: var(--iic-radius-lg);
  overflow: hidden;
  position: sticky;
  top: 90px;
}
.iic-training-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(15, 23, 36, 0.92) 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 26px;
  color: #fff;
}
.iic-training-org {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--iic-primary-lt);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.iic-training-cert-count {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
}

.iic-training-catalog {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.iic-cat-group {
  padding-bottom: 20px;
  border-bottom: 1px solid var(--iic-line);
}
.iic-cat-group:last-child { border-bottom: none; padding-bottom: 0; }
.iic-cat-group-title {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--iic-primary-dk);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--iic-mist);
  display: flex;
  align-items: center;
  gap: 10px;
}
.iic-cat-group-title::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--iic-primary);
  transform: rotate(45deg);
}
.iic-cat-items {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
}
@media (min-width: 500px) { .iic-cat-items { grid-template-columns: 1fr 1fr; gap: 6px; } }
.iic-cat-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--iic-mist);
  border-radius: 3px;
  min-height: 48px;
  transition: background .2s;
}
.iic-cat-item:hover { background: rgba(43, 127, 191, 0.06); }
.iic-cat-code {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--iic-primary-dk);
  background: #fff;
  padding: 4px 8px;
  border-radius: 3px;
  border: 1px solid var(--iic-line);
  flex-shrink: 0;
  min-width: 80px;
  text-align: center;
}
.iic-cat-name {
  font-size: 13px;
  color: var(--iic-ink);
  line-height: 1.4;
  flex: 1;
}

/* ==============================================================
   CERTIFICATIONS
   ============================================================== */
.iic-certs {
  padding: clamp(40px, 6vw, 72px) 0;
  background: var(--iic-mist);
}
.iic-certs-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 900px) { .iic-certs-inner { grid-template-columns: repeat(3, 1fr); } }
.iic-cert-block {
  display: flex;
  gap: 20px;
  padding: 24px;
  background: #fff;
  border-radius: var(--iic-radius-lg);
  border: 1px solid var(--iic-line);
  align-items: flex-start;
}
.iic-cert-ring {
  width: 74px; height: 74px;
  border-radius: 50%;
  border: 3px solid var(--iic-primary);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: var(--iic-mist);
}
.iic-cert-ring-env { border-color: #22c55e; }
.iic-cert-ring-safety { border-color: var(--iic-accent); }
.iic-cert-ring span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--iic-steel);
  line-height: 1;
}
.iic-cert-ring strong {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--iic-ink);
  line-height: 1;
  margin-top: 2px;
}
.iic-cert-body h4 {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--iic-ink);
  margin-bottom: 4px;
}
.iic-cert-body p {
  font-size: 12.5px;
  color: var(--iic-ink-soft);
  line-height: 1.55;
}

/* ==============================================================
   IMAGE BAND
   ============================================================== */
.iic-band {
  position: relative;
  min-height: clamp(220px, 30vw, 360px);
  overflow: hidden;
  background: var(--iic-ink);
}
.iic-band-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: grayscale(30%);
}
.iic-band-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(15, 23, 36, 0.85) 0%, rgba(43, 127, 191, 0.5) 100%);
}
.iic-band-content {
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
  padding: clamp(50px, 7vw, 80px) clamp(12px, 3vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: inherit;
}
.iic-band-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--iic-primary-lt);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.iic-band-quote {
  font-family: var(--font-display);
  font-size: clamp(24px, 4.5vw, 48px);
  font-weight: 500;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -0.02em;
  max-width: 720px;
  margin-bottom: 18px;
}
.iic-band-quote em {
  font-style: italic;
  color: var(--iic-primary-lt);
  font-weight: 400;
}
.iic-band-sig {
  font-family: var(--font-mono);
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 1px;
}

/* ==============================================================
   CONTACT
   ============================================================== */
.iic-contact {
  padding: clamp(56px, 9vw, 110px) 0;
  background: var(--iic-ink);
  color: #fff;
}
.iic-contact-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 4vw, 48px);
}
@media (min-width: 900px) { .iic-contact-grid { grid-template-columns: 1fr 1.3fr; } }

.iic-contact-info {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.iic-contact-person {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 18px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.iic-person-avatar {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--iic-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 1px;
  flex-shrink: 0;
}
.iic-person-name {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  color: #fff;
}
.iic-person-role {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--iic-primary-lt);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: 2px;
}
.iic-contact-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--iic-radius);
  color: inherit;
  text-decoration: none;
  transition: background .2s;
}
.iic-contact-row:not(.iic-contact-row-static):hover {
  background: rgba(43, 127, 191, 0.15);
  border-color: var(--iic-primary-lt);
}
.iic-contact-ico {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: rgba(74, 159, 223, 0.15);
  color: var(--iic-primary-lt);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
.iic-contact-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.iic-contact-value {
  font-size: 14px;
  color: #fff;
  font-weight: 500;
  word-break: break-word;
}

.iic-contact-form {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--iic-radius-lg);
  padding: clamp(24px, 4vw, 36px);
  position: relative;
}
.iic-form-tag {
  position: absolute;
  top: -10px; left: 24px;
  background: var(--iic-primary);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  padding: 4px 10px;
  border-radius: 3px;
}
.iic-form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 520px) { .iic-form-row { grid-template-columns: 1fr 1fr; } }
.iic-field { margin-bottom: 14px; }
.iic-field label {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.iic-field input,
.iic-field select,
.iic-field textarea {
  width: 100%;
  padding: 12px 14px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--iic-radius);
  color: #fff;
  font-family: var(--font-body);
  font-size: 16px;
  outline: none;
  min-height: 48px;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
}
.iic-field select { background-color: rgba(255,255,255,0.05); }
.iic-field select option { background: var(--iic-ink); color: #fff; }
.iic-field input:focus,
.iic-field select:focus,
.iic-field textarea:focus {
  border-color: var(--iic-primary-lt);
  background: rgba(74, 159, 223, 0.08);
}
.iic-field textarea { min-height: 100px; resize: vertical; }
.iic-form-submit {
  width: 100%;
  padding: 15px;
  background: var(--iic-primary);
  color: #fff;
  border: none;
  border-radius: var(--iic-radius);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  margin-top: 6px;
  transition: background .2s;
}
.iic-form-submit:hover { background: var(--iic-primary-dk); }
.iic-form-submit i { font-size: 11px; transition: transform .2s; }
.iic-form-submit:hover i { transform: translateX(4px); }

/* ==============================================================
   FOOTER
   ============================================================== */
.iic-footer {
  background: #050910;
  color: rgba(255,255,255,0.55);
  padding: clamp(40px, 6vw, 64px) 0 0;
}
.iic-footer-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(12px, 3vw, 28px) 32px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
@media (min-width: 640px)  { .iic-footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .iic-footer-grid { grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 40px; } }

.iic-footer-brand .iic-logo-mark-lg { color: #fff; }
.iic-footer-brand h4 {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  margin: 12px 0 8px;
}
.iic-footer-brand p {
  font-size: 13px;
  line-height: 1.7;
}
.iic-footer-col h5 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--iic-primary-lt);
  margin-bottom: 16px;
}
.iic-footer-col ul {
  list-style: none;
  padding: 0;
}
.iic-footer-col ul li {
  margin-bottom: 8px;
  font-size: 13px;
}
.iic-footer-col ul li a {
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  min-height: 32px;
  display: inline-block;
  transition: color .2s;
}
.iic-footer-col ul li a:hover { color: var(--iic-primary-lt); }
.iic-footer-bar {
  max-width: 1280px;
  margin: 0 auto;
  padding: 16px clamp(12px, 3vw, 28px);
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.3);
  text-align: center;
}
@media (min-width: 640px) {
  .iic-footer-bar {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}

/* ==============================================================
   LOGO — Navbar & Footer
   ============================================================== */

/* Navbar logo image */
.iic-nav-logo-img {
  height: clamp(30px, 4.5vw, 42px);
  width: auto;
  max-width: 150px;
  object-fit: contain;
  display: block;
}

/* Footer logo image */
.iic-footer-logo-img {
  height: clamp(36px, 5vw, 52px);
  width: auto;
  max-width: 180px;
  object-fit: contain;
  display: block;
  margin-bottom: 12px;
  /* On dark footer bg, if logo has no transparency, add subtle bg */
  filter: brightness(0) invert(1);
}
.iic-footer-logo-img.iic-logo-no-invert {
  filter: none;
}
