/* =========================================================================
   XONWARE CORPORATE V3 — "Technical Editorial"
   Swiss-influenced corporate system. Scope: html[data-page="home"], [data-page="about"]
   Grammar: massive display type · mono index labels · hairline rules ·
   list-rows (not cards) · navy statement bands · line-drawn schematics.
   No italic serif accents. No uniform card grids.
   ========================================================================= */

:root {
  --xw-ink: #0E1626;
  --xw-navy: #1A237E;
  --xw-leaf: #8BC53F;
  --xw-cyan: #22D3EE;
  --xw-paper: #FFFFFF;
  --xw-rule: rgba(14, 22, 38, 0.12);
  --xw-rule-soft: rgba(14, 22, 38, 0.07);
  --xw-body: #3A4456;
  --xw-mute: #6B7689;
  --xw-max: 1520px;
  --xw-gutter: clamp(20px, 3.5vw, 56px);
  --xw-ease: cubic-bezier(0.22, 0.7, 0.2, 1);
}

/* ---------- Base scope -------------------------------------------------- */
html[data-page="home"] main,
html[data-page="about"] main {
  background: var(--xw-paper);
  color: var(--xw-ink);
}
.xw-wrap {
  max-width: var(--xw-max);
  margin-inline: auto;
  padding-inline: var(--xw-gutter);
}

/* ---------- Type system -------------------------------------------------- */
.xw-display {
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 0.98;
  color: var(--xw-ink);
  margin: 0;
}
.xw-display--xl { font-size: clamp(3rem, 1.2rem + 8vw, 8.5rem); }
.xw-display--lg { font-size: clamp(2.4rem, 1.2rem + 4.4vw, 5.2rem); }
.xw-display--md { font-size: clamp(1.9rem, 1.1rem + 2.6vw, 3.4rem); }
.xw-mono {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--xw-mute);
}
.xw-mono--ink  { color: var(--xw-ink); }
.xw-mono--leaf { color: #5d8a25; }
.xw-body-lg {
  font-size: clamp(1.05rem, 1rem + 0.35vw, 1.3rem);
  line-height: 1.65;
  color: var(--xw-body);
}

/* ---------- Rules + section index ---------------------------------------- */
.xw-rule { border: 0; border-top: 1px solid var(--xw-rule); margin: 0; }
.xw-sechead {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  padding-top: 22px;
  border-top: 1px solid var(--xw-ink);
  flex-wrap: wrap;
}
.xw-sechead .xw-mono { color: var(--xw-ink); }

/* ---------- Reveal motion ------------------------------------------------ */
.xw-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s var(--xw-ease), transform 0.9s var(--xw-ease);
  transition-delay: var(--d, 0ms);
}
.xw-reveal.is-in { opacity: 1; transform: none; }
.xw-mask { overflow: hidden; display: block; }
.xw-mask > span {
  display: block;
  transform: translateY(110%);
  transition: transform 1.05s var(--xw-ease);
  transition-delay: var(--d, 0ms);
}
.xw-mask.is-in > span { transform: none; }
@media (prefers-reduced-motion: reduce) {
  .xw-reveal, .xw-mask > span { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ========================================================================
   HERO — white editorial, massive type, meta row, ticker
   ======================================================================== */
.xw-hero {
  padding-top: clamp(140px, 16vh, 220px);
  position: relative;
}
.xw-hero__meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--xw-rule);
  flex-wrap: wrap;
}
.xw-hero__title {
  margin-top: clamp(48px, 7vw, 96px);
  max-width: 14ch;
}
.xw-hero__title .xw-accent { color: var(--xw-navy); }
.xw-hero__row {
  margin-top: clamp(48px, 6vw, 88px);
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  gap: clamp(32px, 5vw, 96px);
  align-items: end;
  padding-bottom: clamp(56px, 7vw, 104px);
}
.xw-hero__lede { max-width: 46ch; }
.xw-hero__actions {
  display: flex;
  gap: 14px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.xw-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 30px;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-decoration: none;
  border-radius: 0;
  transition: background 0.25s ease, color 0.25s ease, transform 0.15s ease;
}
.xw-btn--ink { background: var(--xw-ink); color: #fff; }
.xw-btn--ink:hover { background: var(--xw-navy); transform: translateY(-2px); }
.xw-btn--line { border: 1px solid var(--xw-ink); color: var(--xw-ink); }
.xw-btn--line:hover { background: var(--xw-ink); color: #fff; }
.xw-btn--ghostwhite { border: 1px solid rgba(255,255,255,.4); color: #fff; }
.xw-btn--ghostwhite:hover { background: #fff; color: var(--xw-ink); }
.xw-btn--leaf { background: var(--xw-leaf); color: var(--xw-ink); }
.xw-btn--leaf:hover { background: #9ed455; transform: translateY(-2px); }

/* Ticker — full-bleed product marquee */
.xw-ticker {
  border-top: 1px solid var(--xw-ink);
  border-bottom: 1px solid var(--xw-ink);
  overflow: hidden;
  white-space: nowrap;
  padding-block: 18px;
  user-select: none;
}
.xw-ticker__track {
  display: inline-flex;
  gap: 64px;
  padding-right: 64px;
  animation: xw-tick 36s linear infinite;
  will-change: transform;
}
.xw-ticker:hover .xw-ticker__track { animation-play-state: paused; }
@keyframes xw-tick { to { transform: translateX(-50%); } }
.xw-ticker__item {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--xw-ink);
  display: inline-flex;
  align-items: center;
  gap: 64px;
}
.xw-ticker__item::after {
  content: '';
  width: 7px; height: 7px;
  background: var(--xw-leaf);
  display: inline-block;
}
@media (prefers-reduced-motion: reduce) { .xw-ticker__track { animation: none; } }

/* ========================================================================
   PRODUCT INDEX — full-width list rows (the anti-card)
   ======================================================================== */
.xw-index { padding-block: clamp(96px, 10vw, 170px) 0; }
.xw-index__rows { margin-top: clamp(40px, 5vw, 72px); border-top: 1px solid var(--xw-rule); }
.xw-row {
  display: grid;
  grid-template-columns: 72px minmax(0, 4.2fr) minmax(0, 3fr) minmax(0, 4.2fr) 56px;
  gap: clamp(16px, 2.5vw, 40px);
  align-items: center;
  padding: clamp(30px, 4vw, 52px) 0;
  border-bottom: 1px solid var(--xw-rule);
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: padding-left 0.35s var(--xw-ease);
}
.xw-row::before {
  content: '';
  position: absolute;
  inset: 0 -100vmax;
  background: var(--xw-ink);
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform 0.42s var(--xw-ease);
  z-index: 0;
}
.xw-row:hover::before { transform: scaleY(1); }
.xw-row > * { position: relative; z-index: 1; transition: color 0.3s ease; }
.xw-row:hover { padding-left: 16px; }
.xw-row:hover .xw-row__num  { color: var(--xw-leaf); }
.xw-row:hover .xw-row__name { color: #fff; }
.xw-row:hover .xw-row__cat  { color: var(--xw-cyan); }
.xw-row:hover .xw-row__desc { color: rgba(255, 255, 255, 0.75); }
.xw-row:hover .xw-row__arrow { color: #fff; transform: translateX(6px); }
.xw-row__num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 13px;
  font-weight: 600;
  color: var(--xw-mute);
}
.xw-row__name {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: clamp(1.7rem, 1rem + 2.4vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--xw-ink);
}
.xw-row__cat {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: #5d8a25;
}
.xw-row__desc {
  font-size: 15px;
  line-height: 1.6;
  color: var(--xw-body);
}
.xw-row__arrow {
  color: var(--xw-ink);
  transition: transform 0.3s var(--xw-ease), color 0.3s ease;
  justify-self: end;
}
@media (max-width: 900px) {
  .xw-row { grid-template-columns: 48px minmax(0, 1fr) 40px; }
  .xw-row__cat { grid-column: 2; grid-row: 2; margin-top: 6px; }
  .xw-row__desc { grid-column: 2; grid-row: 3; margin-top: 10px; }
  .xw-row__arrow { grid-row: 1; }
}

/* ========================================================================
   STATEMENT — pull-quote + newspaper columns
   ======================================================================== */
.xw-statement { padding-block: clamp(110px, 12vw, 200px); }
.xw-statement__quote {
  max-width: 24ch;
}
.xw-statement__quote .xw-underline {
  background-image: linear-gradient(var(--xw-leaf), var(--xw-leaf));
  background-repeat: no-repeat;
  background-size: 0% 6px;
  background-position: 0 92%;
  transition: background-size 1.2s var(--xw-ease) 0.35s;
  padding-bottom: 2px;
}
.xw-statement__quote.is-in .xw-underline { background-size: 100% 6px; }
.xw-statement__cols {
  margin-top: clamp(48px, 6vw, 88px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(32px, 5vw, 88px);
  max-width: 1120px;
}
.xw-statement__cols p {
  font-size: 16.5px;
  line-height: 1.75;
  color: var(--xw-body);
  margin: 0 0 18px;
}
.xw-statement__cols p:last-child { margin-bottom: 0; }
.xw-statement__cols .xw-drop::first-letter {
  font-family: 'Manrope', system-ui, sans-serif;
  font-weight: 800;
  font-size: 3.4em;
  float: left;
  line-height: 0.82;
  margin: 6px 12px 0 0;
  color: var(--xw-navy);
}
@media (max-width: 800px) { .xw-statement__cols { grid-template-columns: 1fr; } }

/* ========================================================================
   NUMBERS BAND — navy full-bleed
   ======================================================================== */
.xw-band {
  background: var(--xw-ink);
  color: #fff;
  padding-block: clamp(96px, 11vw, 180px);
  position: relative;
  overflow: hidden;
}
.xw-band__schematic {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.5;
}
.xw-band .xw-sechead { border-top-color: rgba(255, 255, 255, 0.35); }
.xw-band .xw-sechead .xw-mono { color: rgba(255, 255, 255, 0.7); }
.xw-band__grid {
  margin-top: clamp(56px, 7vw, 100px);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(28px, 4vw, 64px);
  position: relative;
}
.xw-band__cell { border-top: 1px solid rgba(255, 255, 255, 0.25); padding-top: 22px; }
.xw-band__n {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: clamp(3rem, 1.6rem + 4.5vw, 6rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.xw-band__n sup {
  font-size: 0.45em;
  color: var(--xw-leaf);
  font-weight: 700;
  top: -0.7em;
}
.xw-band__l {
  margin-top: 14px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
}
.xw-band__foot {
  margin-top: clamp(56px, 7vw, 96px);
  padding-top: 22px;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.65);
}
@media (max-width: 900px) { .xw-band__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 480px) { .xw-band__grid { grid-template-columns: 1fr; } }

/* ========================================================================
   METHOD — numbered items + line-drawn schematics
   ======================================================================== */
.xw-method { padding-block: clamp(110px, 12vw, 190px); }
.xw-method__list { margin-top: clamp(48px, 6vw, 80px); display: grid; gap: clamp(64px, 8vw, 120px); }
.xw-method__item {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
  gap: clamp(36px, 6vw, 110px);
  align-items: center;
}
.xw-method__item:nth-child(even) { grid-template-columns: minmax(0, 6fr) minmax(0, 5fr); }
.xw-method__item:nth-child(even) .xw-method__copy { order: 2; }
.xw-method__num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 13px;
  font-weight: 600;
  color: #5d8a25;
}
.xw-method__t {
  margin: 18px 0 0;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: clamp(1.5rem, 1rem + 1.6vw, 2.3rem);
  font-weight: 800;
  letter-spacing: -0.026em;
  line-height: 1.08;
  color: var(--xw-ink);
}
.xw-method__d {
  margin: 22px 0 0;
  font-size: 16.5px;
  line-height: 1.72;
  color: var(--xw-body);
  max-width: 46ch;
}
.xw-schematic {
  border: 1px solid var(--xw-rule);
  background: #FBFCFE;
  aspect-ratio: 16 / 10;
  display: grid;
  place-items: center;
  padding: clamp(20px, 3vw, 44px);
}
.xw-schematic svg { width: 100%; height: 100%; }
.xw-schematic [data-draw] {
  stroke-dasharray: var(--len, 600);
  stroke-dashoffset: var(--len, 600);
  transition: stroke-dashoffset 1.6s var(--xw-ease);
  transition-delay: var(--d, 0ms);
}
.xw-schematic.is-in [data-draw] { stroke-dashoffset: 0; }
.xw-schematic [data-pop] {
  opacity: 0;
  transform: scale(0.4);
  transform-origin: center;
  transform-box: fill-box;
  transition: opacity 0.5s ease, transform 0.5s var(--xw-ease);
  transition-delay: var(--d, 0ms);
}
.xw-schematic.is-in [data-pop] { opacity: 1; transform: scale(1); }
@media (max-width: 860px) {
  .xw-method__item,
  .xw-method__item:nth-child(even) { grid-template-columns: 1fr; }
  .xw-method__item:nth-child(even) .xw-method__copy { order: 0; }
}

/* ========================================================================
   TIMELINE (about) — horizontal mono years
   ======================================================================== */
.xw-timeline { padding-block: clamp(96px, 10vw, 160px) 0; }
.xw-timeline__track {
  margin-top: clamp(40px, 5vw, 64px);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: 1px solid var(--xw-ink);
}
.xw-timeline__cell {
  padding: 26px clamp(14px, 2vw, 28px) 40px 0;
  border-right: 1px solid var(--xw-rule);
}
.xw-timeline__cell:last-child { border-right: 0; }
.xw-timeline__year {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 13px;
  font-weight: 600;
  color: #5d8a25;
}
.xw-timeline__t {
  margin-top: 16px;
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--xw-ink);
  line-height: 1.25;
}
.xw-timeline__d {
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.62;
  color: var(--xw-body);
}
@media (max-width: 860px) {
  .xw-timeline__track { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .xw-timeline__cell:nth-child(2n) { border-right: 0; }
  .xw-timeline__cell { border-bottom: 1px solid var(--xw-rule-soft); }
}
@media (max-width: 480px) {
  .xw-timeline__track { grid-template-columns: 1fr; }
  .xw-timeline__cell { border-right: 0; }
}

/* ========================================================================
   FINAL CTA — huge type
   ======================================================================== */
.xw-cta { padding-block: clamp(110px, 13vw, 210px); }
.xw-cta .xw-display--lg { max-width: 15ch; }
.xw-cta__row {
  margin-top: clamp(40px, 5vw, 64px);
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.xw-cta__mail {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 14px;
  color: var(--xw-body);
  text-decoration: none;
  border-bottom: 1px solid var(--xw-rule);
  padding-bottom: 3px;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.xw-cta__mail:hover { color: var(--xw-navy); border-color: var(--xw-navy); }

/* Kill legacy H2 underline + eyebrow styling inside v3 pages */
html[data-page="home"] .xw-sechead h2::after,
html[data-page="about"] .xw-sechead h2::after { display: none !important; }

/* ---------- HERO BACKGROUND IMAGE (slot: hero-editorial.jpg) ------------- */
.xw-hero { position: relative; overflow: hidden; }
.xw-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: 72% 40%; /* focal: right third */
  opacity: 0.5;
  pointer-events: none;
}
.xw-hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  /* heavy white wash: guarantees type contrast; image ghosts through right side */
  background:
    linear-gradient(90deg, #fff 0%, #fff 42%, rgba(255,255,255,0.86) 62%, rgba(255,255,255,0.62) 100%),
    linear-gradient(180deg, #fff 0%, rgba(255,255,255,0.25) 30%, rgba(255,255,255,0.55) 100%);
}
@media (max-width: 800px) {
  .xw-hero__bg { background-position: 78% 40%; opacity: 0.38; }
  .xw-hero__bg::after {
    background: linear-gradient(180deg, #fff 0%, rgba(255,255,255,0.82) 55%, rgba(255,255,255,0.6) 100%);
  }
}

/* ---------- SCROLL SPINE — vertical telecom flow (home, desktop) --------- */
html[data-page="home"] main { position: relative; }
.xw-spine {
  position: absolute;
  top: 0; bottom: 0;
  left: clamp(14px, 1.6vw, 34px);
  width: 40px;
  pointer-events: none;
  z-index: 3;
}
.xw-spine__track {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 1px;
  background: rgba(14, 22, 38, 0.10);
}
.xw-spine__fill {
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  margin-left: -0.5px;
  height: 100%;
  background: linear-gradient(180deg, var(--xw-navy) 0%, var(--xw-cyan) 100%);
  transform-origin: top;
  transform: scaleY(0);
}
.xw-spine__head {
  position: absolute;
  left: 50%;
  top: 0;
  width: 11px; height: 11px;
  margin-left: -5px;
  border-radius: 50%;
  background: var(--xw-leaf);
  box-shadow: 0 0 0 5px rgba(139, 197, 63, 0.18);
}
.xw-spine__node {
  position: absolute;
  left: 50%;
  width: 9px; height: 9px;
  margin-left: -4px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid rgba(14, 22, 38, 0.30);
  transition: background 0.3s ease, border-color 0.3s ease, transform 0.3s var(--xw-ease);
}
.xw-spine__node.is-on {
  background: var(--xw-navy);
  border-color: var(--xw-navy);
  transform: scale(1.25);
}
.xw-spine__lbl {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: rgba(14, 22, 38, 0.35);
  white-space: nowrap;
  writing-mode: vertical-rl;
  transition: color 0.3s ease;
}
.xw-spine__node.is-on + .xw-spine__lbl,
.xw-spine__node.is-on .xw-spine__lbl { color: var(--xw-navy); }
/* Spine sits inside the navy band too — invert there via blend */
.xw-spine { mix-blend-mode: multiply; }
@media (max-width: 1280px) { .xw-spine { display: none; } }
@media (prefers-reduced-motion: reduce) {
  .xw-spine__fill { transform: scaleY(1) !important; }
  .xw-spine__head { display: none; }
}
main { position: relative; }

/* ---------- PHOTO BAND — full-width image slot with caption -------------- */
.xw-photo { padding-block: clamp(24px, 3vw, 56px) 0; }
.xw-photo__img {
  width: 100%;
  aspect-ratio: 21 / 9;
  background: #F1F4F9;
  background-size: cover;
  background-position: center;
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.xw-photo__fallback {
  position: absolute; inset: 0;
  display: grid; place-items: center; gap: 8px;
  background: repeating-linear-gradient(45deg, transparent 0 22px, rgba(14,22,38,.025) 22px 44px), #F1F4F9;
  text-align: center; padding: 20px;
}
.xw-photo__lbl { font-family:'JetBrains Mono',monospace; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#1A237E; }
.xw-photo__hint { font-family:'JetBrains Mono',monospace; font-size:10.5px; color:rgba(14,22,38,.5); letter-spacing:.05em; }
.xw-photo__cap {
  margin-top: 14px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--xw-mute);
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
@media (max-width: 700px) { .xw-photo__img { aspect-ratio: 16 / 10; } }

/* ---------- V3 form skin (contact) --------------------------------------- */
.xw-form { max-width: 760px; }
.xw-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 640px) { .xw-form .form-row { grid-template-columns: 1fr; } }
.xw-form .form-field { margin-bottom: 18px; display: flex; flex-direction: column; gap: 8px; }
.xw-form label { font-family:'JetBrains Mono',monospace; font-size:10.5px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color: var(--xw-ink); }
.xw-form .req { color: #EF4444; }
.xw-form input[type="text"], .xw-form input[type="email"], .xw-form input[type="tel"],
.xw-form select, .xw-form textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--xw-rule);
  border-radius: 0;
  background: #fff;
  font: 500 15px/1.4 'Inter', system-ui, sans-serif;
  color: var(--xw-ink);
  transition: border-color .2s ease;
}
.xw-form input:focus, .xw-form select:focus, .xw-form textarea:focus {
  outline: none; border-color: var(--xw-navy);
}
.xw-form button[type="submit"] {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 18px 32px; border: 0; cursor: pointer;
  background: var(--xw-ink); color: #fff;
  font: 700 15px/1 'Manrope', system-ui, sans-serif; letter-spacing: -0.01em;
  transition: background .25s ease, transform .15s ease;
}
.xw-form button[type="submit"]:hover { background: var(--xw-navy); transform: translateY(-2px); }
.xw-form .form-note, .xw-form .form-help { font-size: 13px; color: var(--xw-mute); }

/* ---------- FAQ accordion (v3) ------------------------------------------- */
.xw-faq { border-top: 1px solid var(--xw-rule); }
.xw-faq__item { border-bottom: 1px solid var(--xw-rule); }
.xw-faq__q {
  display: grid;
  grid-template-columns: 56px 120px minmax(0, 1fr) 40px;
  gap: clamp(14px, 2vw, 32px);
  align-items: center;
  padding: 26px 0;
  cursor: pointer;
  list-style: none;
}
.xw-faq__q::-webkit-details-marker { display: none; }
.xw-faq__num { font-family:'JetBrains Mono',monospace; font-size:12px; font-weight:600; color:var(--xw-mute); }
.xw-faq__cat { font-family:'JetBrains Mono',monospace; font-size:10.5px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:#5d8a25; }
.xw-faq__t { font-family:'Manrope',system-ui,sans-serif; font-size:clamp(1.05rem,1rem + .5vw,1.35rem); font-weight:700; letter-spacing:-.02em; color:var(--xw-ink); }
.xw-faq__toggle { position:relative; width:18px; height:18px; justify-self:end; }
.xw-faq__toggle::before, .xw-faq__toggle::after {
  content:''; position:absolute; background:var(--xw-ink); transition:transform .3s var(--xw-ease);
}
.xw-faq__toggle::before { left:0; right:0; top:8px; height:2px; }
.xw-faq__toggle::after  { top:0; bottom:0; left:8px; width:2px; }
.xw-faq__item[open] .xw-faq__toggle::after { transform: scaleY(0); }
.xw-faq__a { padding: 0 0 30px 56px; max-width: 72ch; }
.xw-faq__a p { font-size:15.5px; line-height:1.75; color:var(--xw-body); margin:0; }
@media (max-width: 720px) {
  .xw-faq__q { grid-template-columns: 40px minmax(0,1fr) 32px; }
  .xw-faq__cat { display:none; }
  .xw-faq__a { padding-left: 0; }
}

/* =========================================================================
   V3 VIBRANCY LAYER — controlled color play
   Per-page accent identity + tinted section washes + color-cycled details.
   ========================================================================= */
:root {
  --xw-violet: #6D28D9;
  --xw-sky: #0284C7;
  --xw-teal: #0D9488;
  --xw-amber: #D97706;
  --xw-rose: #E11D48;
  --xw-page: var(--xw-navy);
}
/* Per-page accent identity */
html[data-page="platform"]          { --xw-page: #1A237E; }
html[data-page="solutions/ipam"]    { --xw-page: #6D28D9; }
html[data-page="solutions/numbers"] { --xw-page: #6D28D9; }
html[data-page="solutions/ddi"]     { --xw-page: #0284C7; }
html[data-page="cybersecurity"]     { --xw-page: #0D9488; }
html[data-page="solutions"]         { --xw-page: #4338CA; }
html[data-page="about"]             { --xw-page: #B45309; }
html[data-page="industries"]        { --xw-page: #0D9488; }
html[data-page="modules"]           { --xw-page: #4338CA; }
html[data-page="mobile"]            { --xw-page: #0284C7; }
html[data-page="integrations"]      { --xw-page: #6D28D9; }
html[data-page="resources"]         { --xw-page: #B45309; }
html[data-page="faq"]               { --xw-page: #0D9488; }
html[data-page="contact"]           { --xw-page: #1A237E; }

/* Gradient display accent (replaces flat navy accent word) */
.xw-accent {
  background: linear-gradient(100deg, var(--xw-navy) 0%, var(--xw-violet) 45%, var(--xw-cyan) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* Hero meta: three colors */
.xw-hero__meta .xw-mono:nth-child(1) { color: var(--xw-page); font-weight: 700; }
.xw-hero__meta .xw-mono:nth-child(2) { color: #5d8a25; }
.xw-hero__meta .xw-mono:nth-child(3) { color: var(--xw-sky); }

/* Section heads pick up page accent */
.xw-sechead { border-top-color: var(--xw-page); }
.xw-sechead .xw-mono:first-child { color: var(--xw-page); font-weight: 700; }

/* Colorful section washes — soft multi-hue radial "illustration" backgrounds */
.xw-index, .xw-statement, .xw-method, .xw-cta, .xw-timeline { position: relative; }
.xw-index::before, .xw-statement::before, .xw-method::before, .xw-cta::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
}
.xw-index::before {
  background:
    radial-gradient(ellipse 42% 55% at 96% 8%,  color-mix(in srgb, var(--xw-page) 7%, transparent), transparent 70%),
    radial-gradient(ellipse 30% 40% at 2% 96%,  rgba(139,197,63,.06), transparent 70%);
}
.xw-statement::before {
  background:
    radial-gradient(ellipse 40% 55% at 4% 10%,  rgba(217,119,6,.055), transparent 70%),
    radial-gradient(ellipse 34% 46% at 98% 88%, rgba(2,132,199,.06), transparent 70%);
}
.xw-method::before {
  background:
    radial-gradient(ellipse 44% 60% at 98% 30%, rgba(109,40,217,.05), transparent 70%),
    radial-gradient(ellipse 30% 44% at 4% 82%,  rgba(13,148,136,.05), transparent 70%);
}
.xw-cta::before {
  background:
    radial-gradient(ellipse 46% 70% at 8% 20%,  color-mix(in srgb, var(--xw-page) 6%, transparent), transparent 70%),
    radial-gradient(ellipse 36% 56% at 94% 84%, rgba(139,197,63,.07), transparent 70%);
}
.xw-index > .xw-wrap, .xw-statement > .xw-wrap, .xw-method > .xw-wrap, .xw-cta > .xw-wrap { position: relative; z-index: 1; }

/* Product rows: color-cycled numbers, categories, hover floods */
.xw-row:nth-child(4n+1) { --row-c: var(--xw-navy); }
.xw-row:nth-child(4n+2) { --row-c: var(--xw-violet); }
.xw-row:nth-child(4n+3) { --row-c: var(--xw-sky); }
.xw-row:nth-child(4n+4) { --row-c: var(--xw-teal); }
.xw-row__num { color: var(--row-c); font-weight: 700; }
.xw-row__cat { color: var(--row-c); }
.xw-row::before { background: var(--row-c); }
.xw-row:hover .xw-row__num { color: rgba(255,255,255,.85); }
.xw-row:hover .xw-row__cat { color: rgba(255,255,255,.85); }

/* Ticker: cycle item colors + dot colors */
.xw-ticker__item:nth-child(5n+1) { color: var(--xw-navy); }
.xw-ticker__item:nth-child(5n+2) { color: var(--xw-violet); }
.xw-ticker__item:nth-child(5n+3) { color: var(--xw-sky); }
.xw-ticker__item:nth-child(5n+4) { color: var(--xw-teal); }
.xw-ticker__item:nth-child(5n+5) { color: var(--xw-amber); }
.xw-ticker__item:nth-child(3n+1)::after { background: var(--xw-leaf); }
.xw-ticker__item:nth-child(3n+2)::after { background: var(--xw-cyan); }
.xw-ticker__item:nth-child(3n+3)::after { background: var(--xw-amber); }
.xw-ticker { border-top-color: var(--xw-page); border-bottom-color: var(--xw-page); }

/* Numbers band: gradient background + per-cell accent colors */
.xw-band {
  background:
    radial-gradient(ellipse 60% 80% at 90% 10%, rgba(109,40,217,.28), transparent 60%),
    radial-gradient(ellipse 50% 70% at 8% 90%,  rgba(13,148,136,.22), transparent 60%),
    linear-gradient(150deg, #0E1626 0%, #131b3f 55%, #0E1626 100%);
}
.xw-band__cell:nth-child(4n+1) { border-top-color: var(--xw-cyan); }
.xw-band__cell:nth-child(4n+2) { border-top-color: var(--xw-leaf); }
.xw-band__cell:nth-child(4n+3) { border-top-color: #A78BFA; }
.xw-band__cell:nth-child(4n+4) { border-top-color: var(--xw-amber); }
.xw-band__cell:nth-child(4n+1) sup { color: var(--xw-cyan); }
.xw-band__cell:nth-child(4n+2) sup { color: var(--xw-leaf); }
.xw-band__cell:nth-child(4n+3) sup { color: #A78BFA; }
.xw-band__cell:nth-child(4n+4) sup { color: var(--xw-amber); }
.xw-band__foot span:nth-child(odd)  { color: rgba(139,197,63,.8); }
.xw-band__foot span:nth-child(even) { color: rgba(34,211,238,.75); }

/* Statement: warm drop cap + gradient underline */
.xw-statement__cols .xw-drop::first-letter { color: var(--xw-page); }
.xw-statement__quote .xw-underline {
  background-image: linear-gradient(90deg, var(--xw-leaf), var(--xw-cyan));
}

/* Method numbers + schematic containers get color */
.xw-method__num { color: var(--xw-page); }
.xw-schematic {
  background:
    radial-gradient(ellipse 60% 70% at 88% 12%, color-mix(in srgb, var(--xw-page) 6%, transparent), transparent 70%),
    #FBFCFE;
  border-color: color-mix(in srgb, var(--xw-page) 22%, #eaeef4);
}

/* Timeline year colors cycle */
.xw-timeline__cell:nth-child(4n+1) .xw-timeline__year { color: var(--xw-navy); }
.xw-timeline__cell:nth-child(4n+2) .xw-timeline__year { color: var(--xw-violet); }
.xw-timeline__cell:nth-child(4n+3) .xw-timeline__year { color: var(--xw-sky); }
.xw-timeline__cell:nth-child(4n+4) .xw-timeline__year { color: var(--xw-teal); }
.xw-timeline__track { border-top-color: var(--xw-page); }

/* FAQ category + toggle colors */
.xw-faq { border-top-color: var(--xw-page); }
.xw-faq__item:nth-child(4n+1) .xw-faq__cat { color: var(--xw-navy); }
.xw-faq__item:nth-child(4n+2) .xw-faq__cat { color: var(--xw-violet); }
.xw-faq__item:nth-child(4n+3) .xw-faq__cat { color: var(--xw-sky); }
.xw-faq__item:nth-child(4n+4) .xw-faq__cat { color: var(--xw-teal); }
.xw-faq__item[open] .xw-faq__toggle::before,
.xw-faq__item[open] .xw-faq__toggle::after { background: var(--xw-page); }

/* Spine: gradient fill + colorful active nodes */
.xw-spine__fill { background: linear-gradient(180deg, var(--xw-navy) 0%, var(--xw-violet) 45%, var(--xw-cyan) 100%); }
.xw-spine__node.is-on { background: var(--xw-page); border-color: var(--xw-page); }
.xw-spine__node.is-on .xw-spine__lbl { color: var(--xw-page); }

/* Buttons: gradient hover */
.xw-btn--ink:hover { background: linear-gradient(120deg, var(--xw-navy), var(--xw-violet)); }
.xw-btn--line:hover { background: var(--xw-page); border-color: var(--xw-page); color: #fff; }
.xw-cta__mail:hover { color: var(--xw-page); border-color: var(--xw-page); }

/* Hero title mask lines: second line subtle color shift on some pages */
.xw-hero__lede strong { color: var(--xw-page); }

/* color-mix fallback for older browsers */
@supports not (color: color-mix(in srgb, red 10%, blue)) {
  .xw-index::before, .xw-cta::before { background: radial-gradient(ellipse 42% 55% at 96% 8%, rgba(26,35,126,.06), transparent 70%); }
  .xw-schematic { background: #FBFCFE; border-color: #dfe5f0; }
}

/* ---------- HERO SLIDER ---------- */
.xw-slider { position: relative; overflow: hidden; }
.xw-slider__stage { position: relative; min-height: clamp(560px, 78vh, 820px); }
.xw-slide {
  position: absolute; inset: 0;
  padding-top: clamp(120px, 14vh, 190px);
  opacity: 0; visibility: hidden;
  transition: opacity .7s var(--xw-ease), visibility 0s linear .7s;
}
.xw-slide.is-active { position: relative; opacity: 1; visibility: visible; transition: opacity .7s var(--xw-ease); }
.xw-slide .xw-accent {
  background: linear-gradient(100deg, var(--slide-accent) 0%, var(--xw-cyan) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.xw-slide .xw-hero__meta .xw-mono:first-child { color: var(--slide-accent); }
.xw-slide .xw-mask > span { transform: translateY(110%); }
.xw-slide.is-active .xw-mask > span { transform: none; }
.xw-slide.is-active .xw-hero__lede,
.xw-slide.is-active .xw-hero__actions { animation: xw-fadein .8s var(--xw-ease) .35s both; }
@keyframes xw-fadein { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }

.xw-slider__ctl {
  display: flex; gap: 22px; align-items: center;
  padding-bottom: 26px;
}
.xw-slider__tab {
  display: flex; align-items: center; gap: 10px;
  background: none; border: 0; padding: 8px 0; cursor: pointer;
}
.xw-slider__tabnum {
  font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 600;
  color: var(--xw-mute); transition: color .3s ease;
}
.xw-slider__tab.is-active .xw-slider__tabnum { color: var(--xw-ink); }
.xw-slider__tabbar {
  display: block; width: 56px; height: 2px;
  background: var(--xw-rule); overflow: hidden;
}
.xw-slider__tabfill {
  display: block; height: 100%; width: 100%;
  background: linear-gradient(90deg, var(--xw-navy), var(--xw-cyan));
  transform: scaleX(0); transform-origin: left;
}
.xw-slider__tab.is-active .xw-slider__tabfill { animation: xw-tabfill var(--dur, 6.5s) linear forwards; }
@keyframes xw-tabfill { to { transform: scaleX(1); } }
.xw-slider.is-paused .xw-slider__tabfill { animation-play-state: paused; }
@media (prefers-reduced-motion: reduce) {
  .xw-slide, .xw-slide.is-active { transition: none; }
  .xw-slider__tab.is-active .xw-slider__tabfill { animation: none; transform: scaleX(1); }
}
@media (max-width: 640px) {
  .xw-slider__stage { min-height: 640px; }
  .xw-slider__ctl { gap: 14px; }
  .xw-slider__tabbar { width: 36px; }
}

/* ---------- SPOTLIGHT SLIDER (scroll-snap) ---------- */
.xw-spot { padding-block: 0 clamp(96px, 10vw, 160px); position: relative; }
.xw-spot__nav { display: inline-flex; gap: 10px; }
.xw-spot__btn {
  width: 40px; height: 40px; border: 1px solid var(--xw-rule);
  background: #fff; cursor: pointer; font-size: 16px; color: var(--xw-ink);
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.xw-spot__btn:hover { background: var(--xw-ink); color: #fff; border-color: var(--xw-ink); }
.xw-spot__track {
  margin-top: clamp(32px, 4vw, 48px);
  display: flex; gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px var(--xw-gutter) 24px calc(max((100vw - var(--xw-max)) / 2, var(--xw-gutter)));
  scrollbar-width: none;
}
.xw-spot__track::-webkit-scrollbar { display: none; }
.xw-spot__card {
  flex: 0 0 clamp(300px, 38vw, 480px);
  scroll-snap-align: start;
  display: flex; flex-direction: column; gap: 14px;
  padding: clamp(32px, 3.5vw, 48px);
  min-height: 320px;
  color: #fff; text-decoration: none;
  background:
    radial-gradient(ellipse 70% 60% at 85% 10%, color-mix(in srgb, var(--c2) 55%, transparent), transparent 65%),
    linear-gradient(150deg, var(--c1) 0%, #0E1626 90%);
  transition: transform .35s var(--xw-ease);
}
.xw-spot__card:hover { transform: translateY(-6px); }
.xw-spot__num { font-family:'JetBrains Mono',monospace; font-size:12px; color: var(--c2); }
.xw-spot__name { font-family:'Manrope',sans-serif; font-size: clamp(1.8rem, 1.2rem + 1.6vw, 2.6rem); font-weight: 800; letter-spacing: -.03em; line-height: 1; }
.xw-spot__cat { font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:.13em; text-transform:uppercase; color: rgba(255,255,255,.7); }
.xw-spot__desc { font-size: 15px; line-height: 1.65; color: rgba(255,255,255,.82); flex: 1; margin-top: 8px; }
.xw-spot__go { font-family:'JetBrains Mono',monospace; font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color: var(--c2); }

/* =========================================================================
   MOBILE FIXES — drawer containing-block trap + v3 responsive pass
   ========================================================================= */

/* 1. THE DRAWER FIX: backdrop-filter on .site-header makes it the containing
   block for position:fixed children, trapping + clipping the nav drawer
   inside the header strip. At drawer widths, strip the filter so the drawer
   escapes to the viewport. Solid background keeps the header legible. */
@media (max-width: 1140px) {
  .site-header,
  .site-header.is-scrolled,
  .site-header--scrolled {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    transform: none !important;
    filter: none !important;
    background: rgba(255, 255, 255, 0.98) !important;
  }
  .nav {
    height: 100vh;
    height: 100dvh;
    z-index: 2001;
  }
  .nav-toggle { z-index: 2002; }
}

/* 2. HERO ROW — collapse the 7/5 grid on mobile; actions left-align */
@media (max-width: 900px) {
  .xw-hero__row {
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: start;
  }
  .xw-hero__actions { justify-content: flex-start; }
  .xw-hero__title { max-width: 100%; }
  .xw-hero__meta { row-gap: 10px; }
  .xw-hero__meta .xw-mono:nth-child(3) { display: none; } /* 3rd meta crowds small screens */
}
@media (max-width: 520px) {
  .xw-hero { padding-top: clamp(104px, 14vh, 140px); }
  .xw-btn { padding: 15px 22px; font-size: 14px; }
  .xw-hero__actions { width: 100%; }
  .xw-hero__actions .xw-btn { flex: 1 1 auto; justify-content: center; }
}

/* 3. Slider stage/ctl on mobile */
@media (max-width: 900px) {
  .xw-slider__stage { min-height: 0; }
  .xw-slide { padding-top: clamp(104px, 13vh, 150px); }
  .xw-slider__ctl { flex-wrap: wrap; gap: 16px; padding-top: 8px; }
}

/* 4. Misc v3 mobile tightening */
@media (max-width: 720px) {
  .xw-sechead { gap: 10px; }
  .xw-sechead .xw-mono:last-child { display: none; } /* right-side label crowds phones */
  .xw-statement__quote, .xw-cta .xw-display--lg { max-width: 100%; }
  .xw-band__foot { gap: 12px; }
  .xw-method__t br { display: none; }
  .xw-photo__cap span:last-child { display: none; }
  .xw-spot__card { flex-basis: min(86vw, 380px); min-height: 280px; }
}
@media (max-width: 480px) {
  .xw-display--xl { font-size: clamp(2.5rem, 11.5vw, 3.4rem); }
  .xw-row { padding-block: 24px; }
  .xw-row__name { font-size: clamp(1.35rem, 6.4vw, 1.8rem); }
  .xw-cta__row { flex-direction: column; align-items: flex-start; }
}
