/* ============================================================
   FENDARI — Security & Agentic AI
   Design system: "Auros" abyssal observatory, retuned to the
   hero video palette (dark blue-charcoal-teal + mint/cyan nodes).
   ============================================================ */

:root {
  /* ---- Surfaces (video-matched) ---- */
  --abyss:   #070707;   /* Void Canvas — page background (Harness) */
  --trench:  #0d0e12;   /* Carbon Plate — card surface */
  --reef:    #141418;   /* Obsidian — elevated / nested panels */
  --reef-2:  #2e3038;   /* Iron Edge — hover / dividers */

  /* ---- Ink ---- */
  --snow:    #ffffff;   /* headings, primary text */
  --fog:     #c8cad0;   /* Ash — body copy */
  --fog-dim: #a2a4a9;   /* Slate Mute — muted */
  --ice:     #a6e5f2;   /* Ice Blue — highlight accents */
  --ash:     #262830;   /* structural borders */

  /* ---- Accents (Harness: phosphor mint + signal blue) ---- */
  --teal:    #70dcd3;   /* Phosphor Mint — signature accent (dots, underlines, hovers) */
  --teal-deep:#3fb9af;
  --cyan:    #00ade4;   /* Current/Signal Blue — links, active states */
  --slate:   #929dbd;   /* Steel Iris — secondary */
  --btn-fg:  #062018;   /* dark text on the mint→cyan CTA */

  /* ---- Gradients ---- */
  --grad-current: linear-gradient(95deg, #70dcd3 0%, #00ade4 100%); /* primary CTA — mint→cyan */
  --grad-aurora:  linear-gradient(90deg, #a6e5f2 0%, #70dcd3 50%, #0092e4 100%); /* accent borders */
  --grad-text:    linear-gradient(120deg, #70dcd3 0%, #00ade4 100%);

  /* ---- Type ---- */
  --font: 'Inter', ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  /* ---- Layout ---- */
  --maxw: 1200px;
  --gutter: 28px;
  --radius-ctrl: 6px;
  --radius-card: 16px;

  --nav-h: 72px;
}

/* ---------------- Reset ---------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; scroll-padding-top: var(--nav-h); -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font);
  background: var(--abyss);
  color: var(--fog);
  line-height: 1.5;
  letter-spacing: 0.2px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, video, canvas { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; color: inherit; background: none; border: 0; }
ul { list-style: none; padding: 0; }

/* atmospheric base glow (the video's centre vignette) */
body::before {
  content: "";
  position: fixed; inset: 0;
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(112,220,211,0.06), transparent 60%),
    radial-gradient(900px 900px at 12% 8%, rgba(0,146,228,0.04), transparent 55%);
  pointer-events: none; z-index: 0;
}

.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }

/* ---------------- Typographic helpers ---------------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 11px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 2.4px; color: var(--fog);
  margin-bottom: 22px;
}
.eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--teal); box-shadow: 0 0 10px rgba(112,220,211,0.9);
}
.section-title {
  font-size: clamp(30px, 5vw, 61px);
  font-weight: 500; line-height: 1.04; letter-spacing: -1.4px;
  color: var(--snow); max-width: 18ch; margin-bottom: 22px;
}
.lead { font-size: clamp(16px, 2vw, 20px); line-height: 1.55; color: var(--fog); max-width: 56ch; }
.lead--wide { max-width: 76ch; }
.muted { color: var(--fog-dim); }
.muted--wide { max-width: 80ch; margin-top: 18px; font-size: 15px; line-height: 1.7; }
.grad-text {
  background: var(--grad-text); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* ---------------- Buttons ---------------- */
.btn {
  --b: transparent;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px; border-radius: 9999px;
  font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 1.44px;
  white-space: nowrap; transition: transform .25s ease, box-shadow .25s ease, opacity .2s;
}
.btn__icon { font-size: 15px; transition: transform .25s ease; }
.btn:hover .btn__icon { transform: translate(2px, -2px); }

.btn--gradient {
  background: #ffffff; color: #070707; font-weight: 600;
  box-shadow: 0 1px 0 0 rgba(255,255,255,0.45) inset, 0 6px 22px -8px rgba(0,0,0,0.55);
}
.btn--gradient:hover { transform: translateY(-2px); box-shadow: 0 1px 0 0 rgba(255,255,255,0.45) inset, 0 10px 30px -8px rgba(0,0,0,0.6); }
.theme-light .btn--gradient { background: #0d0e12; color: #ffffff; }
.theme-light .hero .btn--gradient,
.theme-light .nav:not(.scrolled) .btn--gradient { background: #ffffff; color: #070707; }

.btn--ghost {
  position: relative; background: transparent; color: var(--snow);
}
.btn--ghost::before {
  content: ""; position: absolute; inset: 0; border-radius: 9999px; padding: 1px;
  background: var(--grad-aurora);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: .8; transition: opacity .25s;
}
.btn--ghost:hover { transform: translateY(-2px); }
.btn--ghost:hover::before { opacity: 1; }
.btn--block { width: 100%; justify-content: center; }

/* ---------------- Nav ---------------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  height: var(--nav-h); display: flex; align-items: center;
  transition: background .3s ease, border-color .3s ease, backdrop-filter .3s;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(10,10,12,0.72);
  backdrop-filter: blur(14px) saturate(120%);
  border-bottom-color: var(--ash);
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 11px; }
.brand__mark { width: 30px; height: 30px; }
.brand__word { font-weight: 600; letter-spacing: 3.5px; color: var(--snow); font-size: 18px; }
.nav__links { display: flex; gap: 34px; }
.nav__links a {
  font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 1.44px;
  color: var(--fog); position: relative; padding: 6px 0; transition: color .2s;
}
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 0;
  background: var(--teal); transition: width .25s ease;
}
.nav__links a:hover { color: var(--snow); }
.nav__links a:hover::after { width: 100%; }
.nav__actions { display: flex; align-items: center; gap: 16px; }
.lang-btn {
  font-size: 11px; font-weight: 600; letter-spacing: 1.5px; color: var(--fog);
  border: 1px solid var(--ash); border-radius: var(--radius-ctrl);
  padding: 8px 12px; transition: color .2s, border-color .2s;
}
.lang-btn:hover { color: var(--snow); border-color: var(--teal); }
.nav__toggle { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.nav__toggle span { width: 22px; height: 2px; background: var(--snow); transition: .3s; }

/* ---------------- Hero ---------------- */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  padding-top: var(--nav-h); overflow: hidden; isolation: isolate;
}
.hero__media { position: absolute; inset: 0; z-index: -2; }
.hero__video { width: 100%; height: 100%; object-fit: cover; }
.hero__scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(7,7,9,0.55) 0%, rgba(7,7,9,0.35) 35%, rgba(9,9,11,0.86) 88%, var(--abyss) 100%),
    linear-gradient(90deg, rgba(7,7,9,0.85) 0%, rgba(7,7,9,0.25) 55%, rgba(7,7,9,0.55) 100%);
}
.hero__wash {
  position: absolute; inset: 0; mix-blend-mode: screen; opacity: .5;
  background: radial-gradient(60% 55% at 72% 38%, rgba(112,220,211,0.28), transparent 70%);
}
.hero__content { position: relative; z-index: 1; }
.hero__title {
  font-size: clamp(46px, 9vw, 96px); font-weight: 500; line-height: 0.98;
  letter-spacing: -3px; color: var(--snow); margin-bottom: 26px;
}
.hero__title span { display: block; }
.hero__sub { font-size: clamp(16px, 2.2vw, 20px); color: var(--fog); max-width: 50ch; line-height: 1.55; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 38px; }
.hero__tag {
  margin-top: 40px; font-size: 11px; text-transform: uppercase; letter-spacing: 2px; color: var(--fog-dim);
}
.hero__scroll {
  position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 1;
  width: 26px; height: 42px; border: 1px solid var(--ash); border-radius: 14px;
  display: flex; justify-content: center; padding-top: 8px;
}
.hero__scroll span { width: 3px; height: 8px; border-radius: 3px; background: var(--teal); animation: scroll 1.8s ease-in-out infinite; }
@keyframes scroll { 0%{opacity:0;transform:translateY(-4px)} 40%{opacity:1} 80%{opacity:0;transform:translateY(10px)} 100%{opacity:0} }

/* ---------------- Bands / sections ---------------- */
.band { position: relative; z-index: 1; padding: clamp(72px, 11vw, 128px) 0; }
.band--alt { background: var(--trench); }
.subhead-row { margin-top: 84px; margin-bottom: 8px; }
.subhead { font-size: clamp(22px, 3vw, 36px); font-weight: 500; letter-spacing: -0.6px; color: var(--snow); }

/* split layout */
.split { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(40px, 6vw, 88px); align-items: center; }
.split--reverse .split__visual { order: -1; }
.split__text .lead, .split__text > p { margin-bottom: 18px; }

/* mission / vision */
.mv { display: grid; gap: 26px; margin-top: 36px; }
.mv__item { padding-left: 20px; border-left: 1px solid var(--ash); }
.mv__label {
  display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 2px;
  color: var(--teal); margin-bottom: 8px; font-weight: 500;
}
.mv__item p { font-size: 15px; line-height: 1.6; color: var(--fog); }

/* sphere visual */
.split__visual { position: relative; min-height: 440px; display: flex; align-items: center; justify-content: center; }
.sphere { width: 100%; height: 440px; }
.sphere__glow {
  position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(45% 45% at 50% 50%, rgba(112,220,211,0.22), transparent 70%);
  filter: blur(8px);
}
.network { width: 100%; height: 400px; }

/* ---------------- Stats ---------------- */
.stats { position: relative; z-index: 1; border-block: 1px solid var(--ash); background: var(--trench); }
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 48px 24px; text-align: center; border-left: 1px solid var(--ash); }
.stat:first-child { border-left: 0; }
.stat__num {
  display: block; font-size: clamp(40px, 6vw, 64px); font-weight: 500; letter-spacing: -2px;
  color: var(--snow); line-height: 1;
}
.stat__num em { font-style: normal; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.stat__label { display: block; margin-top: 12px; font-size: 12px; text-transform: uppercase; letter-spacing: 1.4px; color: var(--fog-dim); }

/* ---------------- Grid + cards ---------------- */
.grid { display: grid; gap: 20px; margin-top: 44px; }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

.card {
  position: relative; background: var(--trench); border: 1px solid transparent;
  border-radius: var(--radius-card); padding: 36px 32px;
  transition: transform .3s ease, background .3s ease, border-color .3s ease;
}
.band--alt .card { background: var(--reef); }
.card:hover { transform: translateY(-4px); border-color: var(--ash); background: var(--reef); }
.band--alt .card:hover { background: var(--reef-2); }
.card__title { font-size: 22px; font-weight: 500; letter-spacing: -0.3px; color: var(--snow); margin-bottom: 12px; }
.card p { font-size: 14.5px; line-height: 1.6; color: var(--fog); }
.card__index { font-size: 13px; font-weight: 500; letter-spacing: 2px; color: var(--teal); display: block; margin-bottom: 18px; }
.card__link {
  position: absolute; top: 22px; right: 22px; width: 30px; height: 30px;
  border: 1px solid var(--ash); border-radius: var(--radius-ctrl);
  display: grid; place-items: center; color: var(--ice); font-size: 14px;
  transition: border-color .25s, transform .25s, color .25s;
}
.card:hover .card__link { border-color: var(--teal); transform: translate(2px,-2px); color: var(--cyan); }
.card--svc { padding-top: 30px; }
.tag {
  display: inline-block; font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--cyan); background: rgba(112,220,211,0.12); border: 1px solid rgba(112,220,211,0.25);
  padding: 4px 10px; border-radius: var(--radius-ctrl); margin-bottom: 16px;
}

/* ---------------- Tabs (Concierge) ---------------- */
.tabs { margin-top: 48px; }
.tabs__list { display: flex; flex-wrap: wrap; gap: 8px; border-bottom: 1px solid var(--ash); }
.tabs__btn {
  padding: 14px 22px; font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 1.44px;
  color: var(--fog-dim); position: relative; transition: color .2s;
}
.tabs__btn::after { content:""; position: absolute; left:0; bottom:-1px; height:2px; width:0; background: var(--grad-current); transition: width .3s ease; }
.tabs__btn:hover { color: var(--fog); }
.tabs__btn.is-active { color: var(--snow); }
.tabs__btn.is-active::after { width: 100%; }

.tabs__panel { padding-top: 40px; }
.tabs__panel[hidden] { display: none; }
.tabs__panel.is-active { animation: fade .4s ease; }
@keyframes fade { from{opacity:0; transform: translateY(8px)} to{opacity:1; transform:none} }
.panel-head { margin-bottom: 28px; }
.panel-title { font-size: clamp(24px, 3vw, 36px); font-weight: 500; letter-spacing: -0.6px; color: var(--snow); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.panel-head .muted { margin-top: 12px; max-width: 70ch; font-size: 15px; line-height: 1.65; }
.pill {
  font-size: 10px; text-transform: uppercase; letter-spacing: 1.4px; font-weight: 600;
  color: var(--btn-fg); background: var(--grad-current); padding: 4px 10px; border-radius: 9999px;
}
.pill--free { background: none; color: var(--cyan); border: 1px solid var(--teal); }

.feature-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 36px; }
.feature-list li {
  position: relative; padding-left: 26px; font-size: 14.5px; line-height: 1.5; color: var(--fog);
}
.feature-list li::before {
  content: ""; position: absolute; left: 0; top: 8px; width: 7px; height: 7px; border-radius: 2px;
  background: var(--grad-current); box-shadow: 0 0 8px rgba(112,220,211,0.5);
}
.footnote { margin-top: 22px; font-size: 12.5px; color: var(--fog-dim); line-height: 1.6; max-width: 80ch; }

.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 32px; }
.tier { background: var(--reef); border: 1px solid var(--ash); border-radius: var(--radius-card); padding: 24px; }
.band--alt .tier { background: var(--abyss); }
.tier__name { display: flex; flex-direction: column; gap: 2px; font-size: 17px; font-weight: 500; color: var(--snow); margin-bottom: 12px; }
.tier__name em { font-style: normal; font-size: 12px; letter-spacing: 1px; color: var(--teal); text-transform: uppercase; }
.tier p { font-size: 14px; line-height: 1.6; color: var(--fog); }

/* ---------------- Certifications ---------------- */
.cert-grid { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 40px; }
.cert {
  font-size: 13px; color: var(--fog); background: var(--trench);
  border: 1px solid var(--ash); border-radius: var(--radius-ctrl);
  padding: 12px 18px; transition: border-color .25s, color .25s, transform .25s;
}
.band .cert { background: var(--reef); }
.cert:hover { border-color: var(--teal); color: var(--snow); transform: translateY(-2px); }

/* ---------------- Founder card ---------------- */
.founder-card {
  position: absolute; bottom: 8px; left: 8px; right: 8px;
  display: flex; align-items: center; gap: 16px;
  background: rgba(13,14,18,0.72); backdrop-filter: blur(10px);
  border: 1px solid var(--ash); border-radius: var(--radius-card); padding: 18px 20px;
}
.founder-card__avatar {
  width: 52px; height: 52px; border-radius: 9999px; flex: none;
  display: grid; place-items: center; font-weight: 600; letter-spacing: 1px; color: var(--btn-fg);
  background: var(--grad-current);
}
.founder-card__name { display: block; color: var(--snow); font-weight: 500; font-size: 16px; }
.founder-card__role { display: block; color: var(--fog-dim); font-size: 13px; }
.signature { margin-top: 26px; font-size: 20px; color: var(--snow); font-weight: 500; letter-spacing: -0.2px; }

/* ---------------- Contact ---------------- */
.contact-form { background: var(--abyss); border: 1px solid var(--ash); border-radius: var(--radius-card); padding: 36px; display: grid; gap: 18px; }
.field { display: grid; gap: 8px; }
.field__label { font-size: 11px; text-transform: uppercase; letter-spacing: 1.4px; color: var(--fog-dim); }
.field input, .field textarea {
  font: inherit; font-size: 15px; color: var(--snow);
  background: var(--reef); border: 1px solid var(--ash); border-radius: var(--radius-ctrl);
  padding: 13px 14px; transition: border-color .2s, box-shadow .2s; resize: vertical;
}
.field input::placeholder, .field textarea::placeholder { color: #5d6b71; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px rgba(112,220,211,0.15); }
.contact-direct { margin-top: 26px; font-size: 15px; color: var(--fog); }
.contact-direct a { color: var(--cyan); border-bottom: 1px solid rgba(0,173,228,0.3); }
.contact-direct a:hover { border-color: var(--cyan); }
.form-status { font-size: 14px; min-height: 18px; }
.form-status.ok { color: var(--teal); }
.form-status.err { color: #ff9a9a; }

/* ---------------- Footer ---------------- */
.footer { position: relative; z-index: 1; border-top: 1px solid var(--ash); padding: 64px 0 36px; background: var(--trench); }
.footer__inner { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; padding-bottom: 40px; border-bottom: 1px solid var(--ash); }
.footer__tag { margin-top: 16px; color: var(--fog-dim); font-size: 14px; }
.footer__nav { display: flex; flex-wrap: wrap; gap: 14px 30px; align-content: start; }
.footer__nav a { font-size: 12px; text-transform: uppercase; letter-spacing: 1.44px; color: var(--fog); transition: color .2s; }
.footer__nav a:hover { color: var(--snow); }
.footer__base { padding-top: 26px; font-size: 12px; letter-spacing: 0.5px; color: var(--fog-dim); }

/* ---------------- Reveal animation ---------------- */
.js .reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.js .reveal.in { opacity: 1; transform: none; }

/* ---------------- Responsive ---------------- */
@media (max-width: 1024px) {
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .feature-list { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  :root { --gutter: 20px; }
  .nav__links, .nav__actions .btn { display: none; }
  .nav__toggle { display: flex; }
  .nav__actions { gap: 10px; }
  .split { grid-template-columns: 1fr; }
  .split--reverse .split__visual { order: 0; }
  .grid--3 { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(3) { border-left: 0; }
  .tiers { grid-template-columns: 1fr; }
  .feature-list { grid-template-columns: 1fr; }

  /* mobile menu */
  .nav__links.open {
    display: flex; flex-direction: column; gap: 0;
    position: absolute; top: var(--nav-h); left: 0; right: 0;
    background: rgba(13,14,18,0.96); backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--ash); padding: 8px 20px 20px;
  }
  .nav__links.open a { padding: 16px 0; border-bottom: 1px solid var(--ash); font-size: 14px; }
}
@media (max-width: 560px) {
  .grid--4 { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: 1fr; }
  .stat { border-left: 0; border-top: 1px solid var(--ash); }
  .stat:first-child { border-top: 0; }
  .card { padding: 28px 24px; }
  .contact-form { padding: 24px; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto; }
  .js .reveal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   EXTENSIONS — official logo, security journey, Skillable/CSAT
   feature blocks, and the News / Blog subpages.
   ============================================================ */

/* ---- Official brand logo (CSS mask → recolorable per theme) ---- */
.brand__logo {
  display: block; width: 132px; height: 26px; background-color: currentColor;
  -webkit-mask: url('../assets/fendari-logo.svg') no-repeat left center; -webkit-mask-size: contain;
  mask: url('../assets/fendari-logo.svg') no-repeat left center; mask-size: contain;
  color: var(--snow);
}
.nav:not(.scrolled) .brand__logo { color: #fff; } /* over the dark hero video */
.footer .brand__logo { width: 150px; height: 30px; color: var(--snow); }
.nav__links { gap: 26px; }
.nav__links a.is-current { color: var(--snow); }
.nav__links a.is-current::after { width: 100%; }
.subpage-hero .section-title { max-width: 26ch; }

/* ---- Security Journey (NIST CSF) ---- */
.journey { margin-top: 52px; }
.journey__track { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.journey__step {
  position: relative; background: var(--trench); border-radius: var(--radius-card);
  padding: 26px 20px 24px; overflow: hidden;
  transition: transform .3s ease, background .3s ease;
}
.band--alt .journey__step { background: var(--reef); }
.journey__step::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--grad-current);
  opacity: .85;
}
.journey__step:hover { transform: translateY(-4px); }
.journey__num {
  font-size: 11px; font-weight: 600; letter-spacing: 2px; color: var(--teal);
  display: block; margin-bottom: 14px;
}
.journey__name { font-size: 19px; font-weight: 500; color: var(--snow); letter-spacing: -0.2px; }
.journey__map {
  display: flex; align-items: baseline; gap: 6px; margin: 12px 0 10px; font-size: 13px; font-weight: 500;
  color: var(--cyan); line-height: 1.35;
}
.journey__map .arw { color: var(--teal); font-weight: 600; }
.journey__desc { font-size: 13px; line-height: 1.55; color: var(--fog); }
.journey__note { margin-top: 22px; font-size: 13px; color: var(--fog-dim); }

/* ---- Feature block (Skillable / CSAT) ---- */
.feature-block {
  display: grid; grid-template-columns: 1.25fr 1fr; gap: 40px; align-items: center;
  background: var(--trench); border: 1px solid var(--ash); border-radius: var(--radius-card);
  padding: 40px; margin-top: 30px;
}
.band--alt .feature-block { background: var(--abyss); }
.feature-block__kicker {
  display: inline-flex; align-items: center; gap: 8px; font-size: 10px; text-transform: uppercase;
  letter-spacing: 1.6px; font-weight: 600; color: var(--btn-fg); background: var(--grad-current);
  padding: 5px 12px; border-radius: 9999px; margin-bottom: 18px;
}
.feature-block__title { font-size: clamp(22px, 3vw, 30px); font-weight: 500; letter-spacing: -0.5px; color: var(--snow); margin-bottom: 14px; }
.feature-block__text { font-size: 15px; line-height: 1.65; color: var(--fog); }
.feature-block__aside { background: var(--reef); border: 1px solid var(--ash); border-radius: var(--radius-card); padding: 26px; }
.band--alt .feature-block__aside { background: var(--reef); }
.feature-block__aside h4 { font-size: 12px; text-transform: uppercase; letter-spacing: 1.4px; color: var(--fog-dim); font-weight: 500; margin-bottom: 16px; }
.chip-list { display: flex; flex-direction: column; gap: 12px; }
.chip-list li { position: relative; padding-left: 24px; font-size: 14px; line-height: 1.5; color: var(--fog); }
.chip-list li::before { content: ""; position: absolute; left: 0; top: 7px; width: 7px; height: 7px; border-radius: 2px; background: var(--grad-current); box-shadow: 0 0 8px rgba(112,220,211,.5); }
.chip-list--lead li strong { display: block; color: var(--snow); font-weight: 500; font-size: 14px; margin-bottom: 2px; }

/* Partner logos + audience pills */
.partner-logo { height: 40px; width: auto; margin-top: 24px; }
.audience-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.audience-pill[data-vertical="edu"] { --pc: #00ade4; }
.audience-pill[data-vertical="gov"] { --pc: #70dcd3; }
.audience-pill[data-vertical="biz"] { --pc: #9b8cff; }
.audience-pill { font: inherit; font-size: 11px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--pc, var(--cyan)); background: transparent; border: 1px solid color-mix(in srgb, var(--pc, var(--cyan)) 40%, var(--ash)); border-radius: 9999px; padding: 7px 14px; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; transition: border-color .2s, background .2s, transform .2s; }
.audience-pill::after { content: "↗"; font-size: 12px; opacity: .85; }
.audience-pill:hover { border-color: var(--pc, var(--cyan)); background: color-mix(in srgb, var(--pc, var(--cyan)) 12%, transparent); transform: translateY(-1px); }
.audience-pill:focus-visible { outline: 2px solid var(--pc, var(--cyan)); outline-offset: 2px; }
.partner-logos { display: flex; flex-wrap: wrap; gap: 16px; margin: 36px 0 8px; }
.partner-logo-card { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; min-width: 210px; min-height: 116px; padding: 24px 30px; background: var(--trench); border: 1px solid var(--ash); border-radius: var(--radius-card); transition: border-color .25s, transform .25s; }
.band .partner-logo-card { background: var(--reef); }
.partner-logo-card:hover { border-color: var(--teal); transform: translateY(-3px); }
.partner-logo-card img { height: 74px; width: auto; }
.partner-logo-card--text .plc-name { font-size: 22px; font-weight: 500; color: var(--snow); letter-spacing: -0.3px; }
.partner-logo-card--text .plc-sub { font-size: 12px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--fog-dim); }
.partners-subhead { margin-top: 50px; margin-bottom: 4px; font-size: 22px; }

/* ---- Subpages (News / Blog) ---- */
.subpage { padding-top: var(--nav-h); }
.subpage-hero { position: relative; padding: clamp(56px, 9vw, 104px) 0 clamp(36px, 5vw, 56px); overflow: hidden; }
.subpage-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(60% 70% at 80% 0%, rgba(112,220,211,0.16), transparent 65%),
              radial-gradient(50% 60% at 10% 10%, rgba(0,146,228,0.05), transparent 60%);
}
.subpage-hero .lead { max-width: 64ch; }
.breadcrumb { font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: var(--fog-dim); margin-bottom: 22px; }
.breadcrumb a { color: var(--fog-dim); }
.breadcrumb a:hover { color: var(--snow); }

.post-section { padding: 20px 0 clamp(72px, 10vw, 120px); }
#postList { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.post-card {
  display: flex; flex-direction: column; background: var(--trench); border: 1px solid var(--ash);
  border-radius: var(--radius-card); overflow: hidden; color: inherit;
  transition: transform .3s ease, border-color .3s ease;
}
.post-card:hover { transform: translateY(-5px); border-color: var(--teal); }
.post-card__media { overflow: hidden; background: var(--reef); }
.post-card__media img { width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform .5s ease; }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body { display: flex; flex-direction: column; gap: 10px; padding: 24px; flex: 1; }
.post-card__meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 12px; color: var(--fog-dim); letter-spacing: .4px; }
.post-card__title { font-size: 20px; font-weight: 500; letter-spacing: -0.3px; color: var(--snow); line-height: 1.25; }
.post-card__sum { font-size: 14px; line-height: 1.6; color: var(--fog); }
.post-card__more { margin-top: auto; font-size: 12px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--cyan); }

.post-card--featured { grid-column: 1 / -1; flex-direction: row; }
.post-card--featured .post-card__media { flex: 0 0 54%; }
.post-card--featured .post-card__media img { height: 100%; min-height: 320px; aspect-ratio: auto; }
.post-card--featured .post-card__body { justify-content: center; padding: 44px; gap: 14px; }
.post-card--featured .post-card__title { font-size: clamp(24px, 3vw, 34px); }
.post-card--featured .post-card__sum { font-size: 16px; }

/* ---- Article view ---- */
#postView { max-width: 820px; margin-inline: auto; }
.post-back { display: inline-block; margin-bottom: 28px; font-size: 13px; letter-spacing: .5px; color: var(--cyan); }
.post-back:hover { color: var(--snow); }
.post__meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 13px; color: var(--fog-dim); margin-bottom: 16px; }
.post__title { font-size: clamp(30px, 5vw, 52px); font-weight: 500; letter-spacing: -1.4px; line-height: 1.05; color: var(--snow); margin-bottom: 28px; }
.post__cover { border-radius: var(--radius-card); overflow: hidden; margin-bottom: 36px; border: 1px solid var(--ash); }
.post__cover img { width: 100%; display: block; }
.post__body p { font-size: 17px; line-height: 1.8; color: var(--fog); margin-bottom: 22px; }
.post__body .post-h { font-size: 22px; font-weight: 500; color: var(--snow); letter-spacing: -0.3px; margin: 36px 0 14px; }
.post__body a { color: var(--cyan); border-bottom: 1px solid rgba(0,173,228,.3); }
.post-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 32px; }
.post-gallery__img { width: 100%; border-radius: var(--radius-card); border: 1px solid var(--ash); }
.post-nav { display: flex; justify-content: space-between; gap: 20px; margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--ash); }
.post-nav__link { display: flex; flex-direction: column; gap: 4px; max-width: 45%; font-size: 15px; color: var(--snow); }
.post-nav__link span { font-size: 11px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--fog-dim); }
.post-nav__link--next { text-align: right; margin-left: auto; }
.post-nav__link:hover { color: var(--cyan); }

/* ---- Post modal (opens in front of the list) ---- */
.post-modal {
  position: fixed; inset: 0; margin: auto; /* re-center: our `* { margin: 0 }` reset kills the UA dialog centering */
  width: min(900px, 94vw); max-height: 90vh; padding: 0; border: 1px solid var(--ash);
  border-radius: var(--radius-card); background: var(--reef); color: var(--fog);
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 40px 100px -24px rgba(0,0,0,.75);
}
.post-modal:not([open]) { display: none; }
.post-modal::backdrop { background: rgba(4,4,6,.78); backdrop-filter: blur(6px); }
@keyframes modalIn { from { opacity: 0; transform: translateY(16px) scale(.985); } to { opacity: 1; transform: none; } }
.post-modal[open] { animation: modalIn .28s cubic-bezier(.2,.7,.2,1); }

.post-modal__bar {
  flex: none; display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 14px 22px; border-bottom: 1px solid var(--ash);
  background: rgba(13,14,18,.6); backdrop-filter: blur(8px);
}
.post-modal__back {
  display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 1.2px; color: var(--cyan);
}
.post-modal__back:hover { color: var(--snow); }
.post-modal__count { font-size: 12px; letter-spacing: 1px; color: var(--fog-dim); }
.post-modal__close {
  width: 34px; height: 34px; display: grid; place-items: center; border-radius: var(--radius-ctrl);
  border: 1px solid var(--ash); color: var(--fog); font-size: 15px; transition: border-color .2s, color .2s;
}
.post-modal__close:hover { border-color: var(--teal); color: var(--snow); }

.post-modal__scroll { flex: 1 1 auto; overflow-y: auto; padding: 32px clamp(22px, 4vw, 48px) 8px; }
.post-modal .post { max-width: 100%; }
.post-modal .post__title { font-size: clamp(26px, 4vw, 40px); }

.post-modal__nav {
  flex: none; display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 22px; border-top: 1px solid var(--ash); background: var(--reef);
}
.pm-btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 12px 20px; border-radius: var(--radius-ctrl);
  font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 1.2px;
  border: 1px solid var(--ash); color: var(--snow); background: transparent; transition: border-color .2s, transform .2s, opacity .2s;
}
.pm-btn:hover:not(:disabled) { border-color: var(--teal); transform: translateY(-2px); }
.pm-btn:disabled { opacity: .35; cursor: default; }
.pm-btn--next { background: var(--grad-current); color: var(--btn-fg); font-weight: 600; border-color: transparent; }
.pm-btn--next:disabled { background: none; color: var(--fog-dim); border: 1px solid var(--ash); }
.pm-btn__sub { display: block; font-size: 10px; letter-spacing: 1px; color: var(--fog-dim); text-transform: uppercase; margin-bottom: 1px; }
.pm-next-wrap { margin-left: auto; text-align: right; max-width: 60%; }
.pm-prev-wrap { text-align: left; max-width: 38%; }
@media (max-width: 560px) {
  .post-modal { width: 100vw; max-height: 100vh; height: 100%; border-radius: 0; border: 0; }
  .pm-btn { padding: 11px 14px; }
  .pm-btn .pm-label-full { display: none; }
}

/* ---- Extension responsive ---- */
@media (max-width: 1024px) {
  .journey__track { grid-template-columns: repeat(3, 1fr); }
  #postList { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
  .feature-block { grid-template-columns: 1fr; gap: 28px; padding: 30px; }
  .post-card--featured { flex-direction: column; }
  .post-card--featured .post-card__media { flex: none; }
  .post-card--featured .post-card__media img { min-height: 0; aspect-ratio: 16/10; }
}
@media (max-width: 640px) {
  .journey__track { grid-template-columns: 1fr; }
  #postList { grid-template-columns: 1fr; }
  .post-nav { flex-direction: column; }
  .post-nav__link, .post-nav__link--next { max-width: 100%; text-align: left; }
  .post-gallery { grid-template-columns: 1fr; }
}

/* ============================================================
   THEMING — light / dark.  Default :root = dark (video-matched).
   <html class="theme-light"> = light, matched to the original
   Fendari palette (white / #f5f5f7 / #111 / #6e6e73) with the
   teal accent preserved.  Set before paint by an inline <head>
   script (system preference, overridable + persisted).
   ============================================================ */
:root.theme-light {
  --abyss: #ffffff;
  --trench: #f5f7f8;
  --reef: #eef1f3;
  --reef-2: #e4e8eb;
  --snow: #0a1416;
  --fog: #3c474c;
  --fog-dim: #6b757a;
  --ice: #0e9e92;
  --ash: #e2e6e9;
  --teal: #0e9e92;     /* deeper mint/teal — legible on white */
  --teal-deep: #0b837a;
  --cyan: #0083cc;     /* signal blue on white */
  --slate: #5f6b86;
  --btn-fg: #06201a;   /* dark text for mint accents (pills/avatar) — both themes */
  --grad-current: linear-gradient(95deg, #1bbcae 0%, #00ade4 100%); /* mint→cyan, vivid on white */
  --grad-aurora: linear-gradient(90deg, #0e9e92 0%, #00ade4 100%);
  --grad-text: linear-gradient(120deg, #0e9e92 0%, #0083cc 100%);
}

/* Nav background when scrolled onto the page */
.theme-light .nav.scrolled { background: rgba(255,255,255,0.82); }

/* Nav sits over the dark hero video at the top — keep it light in both themes */
.nav:not(.scrolled) .nav__links a { color: rgba(255,255,255,0.82); }
.nav:not(.scrolled) .nav__links a:hover { color: #fff; }
.nav:not(.scrolled) .lang-btn,
.nav:not(.scrolled) .theme-btn { color: rgba(255,255,255,0.88); border-color: rgba(255,255,255,0.32); }
.nav:not(.scrolled) .nav__toggle span { background: #fff; }

/* Hero text always sits on the dark video — keep it light in both themes */
.hero .eyebrow { color: rgba(233,241,241,0.8); }
.hero__title { color: #fff; }
.hero__sub { color: rgba(233,241,241,0.85); }
.hero__tag { color: rgba(233,241,241,0.5); }
.hero .btn--ghost { color: #fff; }
.hero__scroll { border-color: rgba(255,255,255,0.32); }
.hero__title .grad-text { background-image: linear-gradient(120deg, #70dcd3 0%, #00ade4 100%); }

/* The particle sphere + node network are additive/teal — give them a dark stage on light pages */
.theme-light .split__visual { background: #0d0e12; border: 1px solid #22222a; border-radius: 22px; overflow: hidden; }

/* Modal top bar on light pages */
.theme-light .post-modal__bar { background: rgba(255,255,255,0.8); }

/* Theme toggle button */
.theme-btn { width: 34px; height: 34px; display: grid; place-items: center; border-radius: var(--radius-ctrl); border: 1px solid var(--ash); color: var(--fog); transition: color .2s, border-color .2s; }
.theme-btn:hover { color: var(--snow); border-color: var(--teal); }
.theme-btn svg { width: 17px; height: 17px; }
.theme-btn__moon { display: none; }
.theme-light .theme-btn__sun { display: none; }
.theme-light .theme-btn__moon { display: block; }

/* Smooth cross-fade when toggling */
body, .nav, .card, .feature-block, .journey__step, .cert, .post-card, .footer, .stats, .tier { transition: background-color .35s ease, border-color .35s ease, color .35s ease; }

/* ============================================================
   SECURITY JOURNEY — n8n-style option rail + "canvas" stage.
   Fendari palette; the stage is a dark dotted canvas in both themes.
   ============================================================ */
.journey-ui { display: grid; grid-template-columns: 300px 1fr; gap: 28px; margin-top: 48px; align-items: stretch; }
.journey-tabs { display: flex; flex-direction: column; gap: 6px; }
.journey-tab { text-align: left; display: block; padding: 16px 18px; border-radius: var(--radius-card); border-left: 3px solid transparent; background: transparent; transition: background .25s, border-color .25s; }
.journey-tab:hover { background: var(--trench); }
.band--alt .journey-tab:hover { background: var(--reef); }
.journey-tab.is-active { background: var(--reef); border-left-color: var(--phase, var(--teal)); }
.band--alt .journey-tab.is-active { background: var(--reef-2); }
.journey-tab__name { display: block; font-size: 17px; font-weight: 500; color: var(--snow); letter-spacing: -0.2px; }
.journey-tab__sub { display: block; font-size: 13px; color: var(--fog-dim); margin-top: 3px; line-height: 1.4; }
.journey-tab.is-active .journey-tab__sub { color: var(--fog); }

.journey-stage {
  position: relative; border-radius: 22px; padding: 32px; min-height: 380px;
  display: flex; flex-direction: column; color: #c8cad0;
  background-color: #0d0e12; border: 1px solid #22222a;
  background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 22px 22px; background-position: -6px -6px;
}
.stage-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.stage-phase { font-size: clamp(22px, 3vw, 30px); font-weight: 500; color: #ffffff; letter-spacing: -0.4px; }
.stage-service { font-size: 13px; color: var(--phase, #70dcd3); letter-spacing: 0.3px; font-weight: 500; }
.stage-canvas {
  position: relative; flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px; width: 100%; margin: 14px 0 20px; padding: 30px 16px;
  background: rgba(255,255,255,0.02); border: 1px dashed #2e3038; border-radius: 16px;
  cursor: pointer; transition: border-color .25s, background .25s;
}
.stage-canvas:hover { border-color: var(--phase, var(--teal)); background: color-mix(in srgb, var(--phase, #70dcd3) 7%, transparent); }
.stage-hint { font-size: 11px; text-transform: uppercase; letter-spacing: 1.4px; color: #a2a4a9; }
.stage-canvas:hover .stage-hint { color: var(--phase, #70dcd3); }
.stage-desc { font-size: 15px; line-height: 1.6; color: #aeb1b8; max-width: 64ch; }
.stage-cta { align-self: flex-start; margin-top: 22px; }

/* flow diagram (mini canvas) */
.flow { display: flex; align-items: center; justify-content: center; gap: 8px; flex-wrap: wrap; width: 100%; }
.flow-node { display: flex; flex-direction: column; align-items: center; gap: 9px; width: 120px; flex: none; }
.flow-node__ico { width: 54px; height: 54px; border-radius: 12px; display: grid; place-items: center; background: #141418; border: 1px solid #2e3038; color: #c8cad0; }
.flow-node__ico svg { width: 24px; height: 24px; }
.flow-node--accent .flow-node__ico { border-color: transparent; color: #062018; background: linear-gradient(160deg, color-mix(in srgb, var(--phase, #70dcd3) 70%, #ffffff) 0%, var(--phase, #70dcd3) 72%); box-shadow: 0 0 26px -4px color-mix(in srgb, var(--phase, #70dcd3) 55%, transparent); }
.flow-node__lbl { font-size: 12px; line-height: 1.3; text-align: center; color: #a2a4a9; }
.flow-conn { flex: 1; min-width: 24px; height: 2px; background: linear-gradient(90deg, color-mix(in srgb, var(--phase, #70dcd3) 25%, transparent), var(--phase, #70dcd3)); position: relative; }
.flow-conn::after { content: ""; position: absolute; right: -1px; top: 50%; transform: translateY(-50%); border-left: 6px solid var(--phase, #70dcd3); border-top: 4px solid transparent; border-bottom: 4px solid transparent; }

/* journey modal extras */
.journey-modal__flow { margin: 6px 0 26px; padding: 26px 18px; border-radius: 16px; background-color: #0d0e12; border: 1px solid #22222a; color: #c8cad0; background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px); background-size: 22px 22px; }
.feature-list--modal { grid-template-columns: 1fr 1fr; margin-top: 10px; }
.journey-modal__cta { margin-top: 26px; }

@media (max-width: 860px) {
  .journey-ui { grid-template-columns: 1fr; }
  .journey-tabs { flex-direction: row; overflow-x: auto; gap: 8px; padding-bottom: 6px; }
  .journey-tab { border-left: 0; border-bottom: 3px solid transparent; min-width: 210px; flex: none; }
  .journey-tab.is-active { border-left: 0; border-bottom-color: var(--phase, var(--teal)); }
  .flow { flex-direction: column; }
  .flow-conn { width: 2px; min-width: 0; height: 26px; background: linear-gradient(180deg, color-mix(in srgb, var(--phase, #70dcd3) 25%, transparent), var(--phase, #70dcd3)); }
  .flow-conn::after { right: 50%; top: auto; bottom: -1px; transform: translateX(50%); border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 6px solid var(--phase, #70dcd3); border-bottom: 0; }
  .feature-list--modal { grid-template-columns: 1fr; }
}

/* ============================================================
   "WOW" FEATURE CARDS — Harness-style inner corner glow, a
   distinct accent colour per card. Glow sits behind the content.
   ============================================================ */
.card, .feature-block { position: relative; overflow: hidden; isolation: isolate; }
.card::after, .feature-block::after {
  content: ""; position: absolute; z-index: -1; top: -30%; right: -16%;
  width: 70%; height: 85%; border-radius: 50%; pointer-events: none;
  opacity: .22; transition: opacity .35s ease;
  background: radial-gradient(circle, var(--cardglow, #70dcd3) 0%, transparent 68%);
}
.card:hover::after, .feature-block:hover::after { opacity: .4; }
/* distinct accent per card position */
.grid--4 .card:nth-child(4n+1) { --cardglow: #70dcd3; }
.grid--4 .card:nth-child(4n+2) { --cardglow: #00ade4; }
.grid--4 .card:nth-child(4n+3) { --cardglow: #75ae4c; }
.grid--4 .card:nth-child(4n)   { --cardglow: #929dbd; }
.grid--3 .card:nth-child(3n+1) { --cardglow: #70dcd3; }
.grid--3 .card:nth-child(3n+2) { --cardglow: #a6e5f2; }
.grid--3 .card:nth-child(3n)   { --cardglow: #75ae4c; }
#csat { --cardglow: #00ade4; }
#skillable { --cardglow: #75ae4c; }

/* ============================================================
   PARTNER WALL — colour logos on white chips (legible on dark),
   role caption beneath. Missing logos fall back to the name (JS).
   ============================================================ */
.partner-wall { display: flex; flex-wrap: wrap; gap: 18px; margin: 34px 0 8px; }
.partner-wall--two { max-width: 540px; }
.partner-card { display: flex; flex-direction: column; align-items: center; gap: 12px; flex: 1 1 190px; max-width: 250px; }
.partner-card__chip { display: grid; place-items: center; width: 100%; min-height: 104px; padding: 22px 26px; background: #ffffff; border-radius: var(--radius-card); transition: transform .25s ease; }
.partner-card:hover .partner-card__chip { transform: translateY(-3px); }
.partner-card__chip img { max-height: 46px; max-width: 100%; width: auto; display: block; }
.partner-card__chip:has(img[src*="qs-solutions"]) { padding: 8px; }
.partner-card__chip img[src*="qs-solutions"] { max-height: 88px; }
.partner-card__chip:has(img[src*="unlimitech"]) { padding: 16px; }
.partner-card__chip img[src*="unlimitech"] { max-height: 66px; }
.partner-card__chip:has(img[src*="skillable"]) { padding: 16px; }
.partner-card__chip img[src*="skillable"] { max-height: 60px; transform: translateY(-10px); }
.partner-card__chip:has(img[src*="bluevoyant"]) { padding: 10px 14px; }
.partner-card__chip img[src*="bluevoyant"] { max-height: 56px; }
.partner-card__chip:has(img[src*="microsoft"]) { padding: 12px 16px; }
.partner-card__chip img[src*="microsoft"] { max-height: 58px; }
.partner-card__name { color: #0d0e12; font-weight: 700; font-size: 19px; letter-spacing: -0.2px; text-align: center; }
.partner-card__role { font-size: 12px; text-transform: uppercase; letter-spacing: 1.1px; color: var(--fog-dim); text-align: center; line-height: 1.35; }

/* Skillable badge inside the Learning feature block (logo on white chip) */
.skillable-badge { display: inline-grid; place-items: center; background: #ffffff; border-radius: 10px; padding: 8px 18px; margin-bottom: 18px; }
.skillable-badge img { height: 48px; width: auto; display: block; }
.skillable-badge .partner-card__name { font-size: 16px; }

/* ============================================================
   SKILLABLE VERTICAL MODAL (Universities / Government / Business)
   Reuses .post-modal shell; per-vertical accent via --phase.
   ============================================================ */
.skill-modal__chip { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.2px; color: var(--phase, var(--cyan)); }
.skill-modal__title { font-size: clamp(24px, 4vw, 36px); font-weight: 500; color: var(--snow); letter-spacing: -0.5px; margin-bottom: 4px; }
.skill-modal__sub { font-size: 12px; text-transform: uppercase; letter-spacing: 1.4px; color: var(--fog-dim); margin-bottom: 18px; }
.skill-modal__focus { font-size: 16px; line-height: 1.6; color: var(--fog); max-width: 66ch; margin-bottom: 26px; }
.skill-cases { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 24px; }
.skill-case { position: relative; overflow: hidden; isolation: isolate; background: var(--trench); border: 1px solid var(--ash); border-radius: var(--radius-card); padding: 20px; }
.skill-case::after {
  content: ""; position: absolute; z-index: -1; top: -34%; right: -18%; width: 64%; height: 82%;
  border-radius: 50%; pointer-events: none; opacity: .18;
  background: radial-gradient(circle, var(--phase, #70dcd3) 0%, transparent 70%);
}
.skill-case__ic { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; margin-bottom: 14px; color: var(--phase, var(--cyan)); background: color-mix(in srgb, var(--phase, #70dcd3) 16%, transparent); }
.skill-case__ic svg { width: 22px; height: 22px; }
.skill-case h3 { font-size: 16px; font-weight: 600; color: var(--snow); margin-bottom: 6px; letter-spacing: -0.2px; }
.skill-case p { font-size: 14px; line-height: 1.55; color: var(--fog-dim); }
.skill-certs { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 24px; }
.skill-certs__lbl { font-size: 11px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--fog-dim); margin-right: 4px; }
.skill-cert { font-size: 12px; color: var(--fog); border: 1px solid var(--ash); border-radius: 9999px; padding: 5px 12px; }
.skill-bens { display: flex; flex-wrap: wrap; gap: 12px 22px; padding: 18px 0 4px; border-top: 1px solid var(--ash); }
.skill-ben { font-size: 13px; color: var(--fog); display: inline-flex; align-items: center; gap: 8px; }
.skill-ben::before { content: "✓"; color: var(--phase, var(--cyan)); font-weight: 700; }
.skill-modal__cta { margin: 20px 0 6px; }
@media (max-width: 620px) { .skill-cases { grid-template-columns: 1fr; } }

/* Honeypot anti-spam field for the contact form — hidden from humans */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
