/* =================================================================
   iTec — Design System  (Montserrat · deep-ink + mint accent)
   ================================================================= */

/* ---------- Tokens ---------- */
:root {
	--ink:          #0b132b;
	--ink-2:        #111a36;
	--ink-3:        #18213f;
	--surface:      rgba(17, 26, 54, 0.6);
	--surface-line: rgba(4, 229, 172, 0.2);
	--surface-line-strong: rgba(4, 229, 172, 0.38);

	--mint:         #04e5ac;
	--mint-soft:    rgba(4, 229, 172, 0.14);
	--mint-dim:     #06b88a;

	--text:         #eef2f8;
	--text-muted:   #9aa6bd;
	--text-faint:   #66728c;

	--light:        #f1f5f9;
	--light-2:      #f8fafc;
	--light-ink:    #0b132b;
	--light-muted:  #475569;

	--gradient-ember: linear-gradient(135deg, #04e5ac, #06cfc6);
	--gradient-radial-ember: radial-gradient(closest-side, rgba(4, 229, 172, 0.35), transparent 70%);
	--gradient-text: linear-gradient(110deg, #2bf0bd, #5fe6e0);

	--shadow-glow:     0 0 0 1px rgba(4, 229, 172, 0.25), 0 12px 50px -12px rgba(4, 229, 172, 0.4);
	--shadow-elevated: 0 30px 80px -30px rgba(0, 0, 0, 0.8);

	--font-display: 'Montserrat', system-ui, -apple-system, sans-serif;
	--font-body:    'Montserrat', system-ui, -apple-system, sans-serif;
	--font-mono:    'Montserrat', system-ui, -apple-system, sans-serif;

	--container: 1240px;
	--gutter: clamp(1.25rem, 4vw, 3rem);
	--radius: 18px;
	--radius-sm: 12px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: clip; }
body {
	font-family: var(--font-body);
	background: var(--ink);
	color: var(--text);
	line-height: 1.6;
	font-weight: normal;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; padding: 0; }
::selection { background: var(--mint); color: var(--ink); }

/* ---------- Utilities ---------- */
.container-x { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.eyebrow { display: inline-flex; align-items: center; gap: 0.6rem; font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mint); }
.eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--mint); opacity: 0.7; }
.section-light .eyebrow, .section-lighter .eyebrow { color: var(--mint-dim); }
.text-gradient { background: var(--gradient-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.serif { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.02; }
.serif-i { font-family: var(--font-display); font-style: italic; letter-spacing: -0.02em; }
.surface-card { background: var(--surface); border: 1px solid var(--surface-line); border-radius: var(--radius); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }

.btn { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 600; font-size: 0.95rem; padding: 0.85rem 1.5rem; border-radius: 999px; transition: transform .25s ease, box-shadow .3s ease, background .3s ease, color .3s ease; white-space: nowrap; }
.btn .icon { transition: transform .3s ease; }
.btn-primary { background: var(--gradient-ember); color: #0b132b; font-weight: 600; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.btn-primary:hover .icon { transform: translateX(3px); }
.btn-ghost { background: transparent; color: var(--text); border: 1px solid var(--surface-line-strong); }
.btn-ghost:hover { border-color: var(--mint); color: var(--mint); transform: translateY(-2px); }
.section-light .btn-ghost, .section-lighter .btn-ghost { color: var(--light-ink); border-color: rgba(11, 19, 43, 0.22); }
.section-light .btn-ghost:hover, .section-lighter .btn-ghost:hover { color: var(--mint-dim); border-color: var(--mint-dim); }

.noise::after { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0.035; z-index: 1; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.section { position: relative; padding-block: clamp(3rem, 6vw, 6rem); }
.section-dark { background: var(--ink); }
.section-light { background: var(--light); color: var(--light-ink); }
.section-lighter { background: var(--light-2); color: var(--light-ink); }
.section-light .serif, .section-lighter .serif { color: var(--light-ink); }
.section-light .serif-i:not(.text-gradient), .section-lighter .serif-i:not(.text-gradient) { color: var(--mint-dim); }
.section-green { background: linear-gradient(135deg, #04e5ac 0%, #06b88a 100%); color: var(--ink); }
.section-green .serif { color: var(--ink); }
.section-green p { color: rgba(11, 19, 43, 0.82); }
.section-green .eyebrow { color: var(--ink); }
.section-green .eyebrow::before { background: var(--ink); opacity: 0.6; }
.section-green .text-gradient { background: none; -webkit-background-clip: border-box; background-clip: border-box; -webkit-text-fill-color: var(--ink); color: var(--ink); }
.section-green .btn-primary { background: var(--ink); color: #fff; }
.section-green .btn-primary:hover { box-shadow: 0 12px 40px -12px rgba(11, 19, 43, 0.6); }
.section-green .btn-ghost { border-color: rgba(11, 19, 43, 0.35); color: var(--ink); }
.section-green .btn-ghost:hover { border-color: var(--ink); color: var(--ink); background: rgba(11, 19, 43, 0.06); }
.section-light p, .section-lighter p { color: var(--light-muted); }

.section-header { max-width: 640px; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-header.center { margin-inline: auto; text-align: center; }
.section-header h2 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.4rem); line-height: 1.05; margin: 1rem 0 1.1rem; }
.section-header p { color: var(--text-muted); font-size: 0.95rem; max-width: 52ch; }
.section-header.center p { margin-inline: auto; }

[data-reveal] { opacity: 0; transform: translateY(30px); transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
[data-reveal].is-visible { opacity: 1; transform: none; }
.ghost-num { font-family: var(--font-display); font-weight: 600; line-height: 1; -webkit-text-stroke: 1px var(--surface-line-strong); color: transparent; pointer-events: none; user-select: none; }

/* ---------- Global layers ---------- */
#scroll-progress { position: fixed; top: 0; left: 0; height: 2px; width: 0; z-index: 200; background: var(--gradient-ember); box-shadow: 0 0 12px var(--mint); }
#cursor-spotlight { position: fixed; top: 0; left: 0; width: 520px; height: 520px; border-radius: 50%; z-index: 1; pointer-events: none; transform: translate(-50%, -50%); background: var(--gradient-radial-ember); opacity: 0; transition: opacity .4s ease; mix-blend-mode: screen; }
@media (hover: hover) and (pointer: fine) { body:hover #cursor-spotlight { opacity: 0.5; } }
#loader { position: fixed; inset: 0; z-index: 300; background: var(--ink); display: grid; place-items: center; transition: opacity .6s ease, visibility .6s; }
#loader.is-done { opacity: 0; visibility: hidden; }
#loader .loader__mark { font-family: var(--font-display); font-size: 2.4rem; color: var(--text); letter-spacing: -0.02em; }
#loader .loader__mark span { color: var(--mint); }
#loader .loader__bar { width: 160px; height: 2px; margin-top: 1.2rem; background: var(--surface-line-strong); overflow: hidden; border-radius: 2px; }
#loader .loader__bar i { display: block; height: 100%; width: 40%; background: var(--gradient-ember); animation: loaderbar 1s ease-in-out infinite; }
@keyframes loaderbar { 0% { transform: translateX(-120%); } 100% { transform: translateX(320%); } }

/* ---------- Header / Nav ---------- */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding-top: 1.1rem; padding-bottom: 0; transition: padding .35s ease, background .35s ease, box-shadow .35s ease, backdrop-filter .35s ease; }
.site-header.is-shrunk { padding-top: 0.55rem; padding-bottom: 0.55rem; background: rgba(11, 19, 43, 0.72); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); border-bottom: 1px solid var(--surface-line); box-shadow: 0 14px 40px -24px rgba(0, 0, 0, 0.7); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; }

/* Brand logo (adapts to any background via blend) */
.nav__logo { display: inline-flex; flex-direction: column; line-height: 0.92; color: #fff; }
.nav__logo-mark { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; letter-spacing: -0.01em; }
.nav__logo-sub { font-family: var(--font-display); font-weight: 400; font-size: 0.58rem; letter-spacing: 0.22em; text-transform: uppercase; opacity: 0.85; margin-top: 1px; }
.nav__logo-img { display: block; height: 54px; width: auto; filter: brightness(0) invert(1); }

/* White pill of inline links */
.nav__bar { display: flex; align-items: center; gap: 0.2rem; background: #fff; border-radius: 999px; padding: 0.4rem 0.4rem 0.4rem 1rem; box-shadow: 0 12px 40px -20px rgba(11, 19, 43, 0.55); }
.nav__link { font-family: var(--font-display); font-weight: 600; font-size: 0.8rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--light-ink); padding: 0.6rem 0.85rem; border-radius: 999px; transition: color .25s ease, background .25s ease; white-space: nowrap; background: none; cursor: pointer; }
.nav__link:hover { color: var(--mint-dim); }
.nav__cta { text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.04em; padding: 0.65rem 1.15rem; margin-left: 0.3rem; }

/* Services dropdown */
.nav__dd { position: relative; }
.nav__dd-btn { display: inline-flex; align-items: center; gap: 0.35rem; }
.nav__dd-btn .icon { transition: transform .3s ease; }
.nav__dd:hover .nav__dd-btn .icon, .nav__dd:focus-within .nav__dd-btn .icon { transform: rotate(180deg); }
.nav__dd-menu { position: absolute; top: calc(100% + 0.7rem); left: 50%; transform: translateX(-50%) translateY(8px); min-width: 250px; background: #fff; border-radius: 16px; box-shadow: 0 30px 60px -25px rgba(11, 19, 43, 0.4); padding: 0.6rem; opacity: 0; visibility: hidden; transition: opacity .25s ease, transform .25s ease; display: grid; gap: 0.1rem; }
.nav__dd:hover .nav__dd-menu, .nav__dd:focus-within .nav__dd-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.nav__dd-menu a { font-family: var(--font-display); font-size: 0.85rem; color: var(--light-ink); padding: 0.7rem 1rem; border-radius: 10px; transition: background .2s ease, color .2s ease; white-space: nowrap; }
.nav__dd-menu a:hover { background: rgba(4, 229, 172, 0.1); color: var(--mint-dim); }

/* Hamburger */
.nav__burger { display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; width: 46px; height: 46px; mix-blend-mode: difference; }
.nav__burger span { display: block; width: 24px; height: 2px; background: #fff; border-radius: 2px; }

@media (max-width: 980px) { .nav__bar { display: none; } }

/* ---------- Fullscreen overlay menu ---------- */
.navmenu { position: fixed; inset: 0; z-index: 200; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .4s ease, visibility .4s ease; overflow-y: auto; background: radial-gradient(circle at 85% 85%, rgba(4, 229, 172, 0.14), transparent 50%), linear-gradient(135deg, #0b132b 0%, #081626 100%); }
.navmenu.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
body.nav-open { overflow: hidden; }
.navmenu__inner { position: relative; min-height: 100vh; display: flex; flex-direction: column; padding-top: clamp(1.4rem, 4vw, 2.4rem); padding-bottom: clamp(2rem, 5vw, 4rem); }
.navmenu__top { display: flex; align-items: center; justify-content: space-between; position: relative; z-index: 3; }
.navmenu__close { width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--surface-line-strong); color: var(--text); display: grid; place-items: center; transition: border-color .3s ease, color .3s ease, transform .3s ease; }
.navmenu__close:hover { border-color: var(--mint); color: var(--mint); transform: rotate(90deg); }
.navmenu__body { position: relative; z-index: 2; flex: 1; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-content: center; padding-block: clamp(2rem, 5vw, 4rem); }
.navmenu__list { display: grid; gap: 0.3rem; list-style: none; margin: 0; padding: 0; }
.navmenu__list a { display: flex; align-items: baseline; gap: 1rem; padding: 0.5rem 0; color: var(--text); font-family: var(--font-display); font-weight: 600; font-size: clamp(1.4rem, 3vw, 2.1rem); transition: color .25s ease, gap .25s ease; }
.navmenu__list a:hover { color: var(--mint); gap: 1.4rem; }
.navmenu__num { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; color: var(--mint); flex: 0 0 auto; }
.navmenu__svc-arrow { font-size: 0.85em; }
.navmenu__panel { align-self: center; }
.navmenu__panel-title { display: block; font-family: var(--font-display); font-weight: 600; font-size: 1.1rem; color: var(--text); margin-bottom: 1.4rem; }
.navmenu__panel ul { display: grid; gap: 1rem; list-style: none; margin: 0; padding: 0; }
.navmenu__panel a { color: var(--text-muted); font-size: 1.05rem; transition: color .25s ease, padding-left .25s ease; }
.navmenu__panel a:hover { color: var(--mint); padding-left: 6px; }
.navmenu__watermark { position: absolute; right: 0; bottom: 0; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: clamp(8rem, 22vw, 18rem); line-height: 0.7; color: rgba(4, 229, 172, 0.05); pointer-events: none; user-select: none; }
@media (max-width: 760px) {
	.navmenu__body { grid-template-columns: 1fr; gap: 1.6rem; align-content: start; }
	.navmenu__panel { padding-left: 2rem; border-left: 1px solid var(--surface-line); }
}

/* ---------- Hero ---------- */
.hero { position: relative; min-height: auto; display: flex; align-items: center; padding-top: clamp(6.5rem, 9vh, 7.5rem); padding-bottom: clamp(2.5rem, 5vh, 3.5rem); overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.hero__bg .glow-a { position: absolute; top: -10%; right: -5%; width: 50vw; height: 50vw; background: var(--gradient-radial-ember); opacity: 0.5; }
.hero__bg .glow-b { position: absolute; bottom: -20%; left: -10%; width: 45vw; height: 45vw; background: radial-gradient(closest-side, rgba(6, 110, 130, 0.35), transparent 70%); }
.hero__grid { position: absolute; inset: 0; opacity: 0.4; background-image: linear-gradient(var(--surface-line) 1px, transparent 1px), linear-gradient(90deg, var(--surface-line) 1px, transparent 1px); background-size: 64px 64px; -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, #000, transparent 75%); mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, #000, transparent 75%); }
.hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; width: 100%; }
.hero__headline { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.04; font-size: clamp(2rem, 4.4vw, 3.4rem); margin: 1.2rem 0 1.4rem; }
.hero__sub { font-size: clamp(1.05rem, 1.5vw, 1.25rem); color: var(--text-muted); max-width: 46ch; margin-bottom: 2.2rem; }
.hero__ctas { display: flex; flex-wrap: wrap; gap: 0.9rem; margin-bottom: 2.8rem; }
.hero__meta { display: flex; gap: 2.5rem; flex-wrap: wrap; }
.hero__meta .stat .num { font-family: var(--font-display); font-size: 1.9rem; color: var(--text); }
.hero__meta .stat .lbl { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); }
.composition { position: relative; aspect-ratio: 1/1.05; perspective: 1200px; }
.composition__inner { position: absolute; inset: 0; transform-style: preserve-3d; transition: transform .2s ease-out; }
.float-card { position: absolute; border-radius: var(--radius); padding: 1.2rem 1.3rem; }
.float-card.main { inset: 12% 8% 18% 10%; padding: 1.4rem 1.4rem 3rem; background: var(--surface); border: 1px solid var(--surface-line-strong); backdrop-filter: blur(14px); box-shadow: var(--shadow-elevated); display: flex; flex-direction: column; justify-content: space-between; }
.float-card.pill { top: 6%; right: 2%; background: rgba(11, 19, 43, 0.82); border: 1px solid var(--surface-line-strong); display: flex; align-items: center; gap: 0.6rem; backdrop-filter: blur(10px); }
.float-card.kpi { bottom: 4%; left: -2%; background: var(--gradient-ember); color: #0b132b; box-shadow: var(--shadow-glow); z-index: 3; }
.float-card.kpi .big { font-family: var(--font-display); font-size: 2.2rem; line-height: 1; }
.float-card .chip { width: 36px; height: 36px; border-radius: 10px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; }
.float-card .tag { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); }
.float-card.kpi .tag { color: #0b132b; }
.float-card__title { font-size: 1.6rem; margin-top: 0.6rem; }
.float-card__meta { display: flex; align-items: center; gap: 0.7rem; }
.float-card__meta span:last-child { color: var(--text-muted); font-size: 0.85rem; }
.float-card.pill span:last-child { font-size: 0.82rem; }
.hero__visuals { position: absolute; inset: 0; display: grid; }
.hero__visual-set { grid-area: 1 / 1; position: relative; opacity: 0; visibility: hidden; transform: translateY(10px) scale(0.985); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1), visibility .7s; pointer-events: none; }
.hero__visual-set.is-active { opacity: 1; visibility: visible; transform: none; pointer-events: auto; }
.composition .orb { position: absolute; border-radius: 50%; background: var(--gradient-radial-ember); filter: blur(8px); }
.composition .orb.o1 { width: 80px; height: 80px; top: 20%; right: 14%; animation: float 6s ease-in-out infinite; }
.composition .orb.o2 { width: 50px; height: 50px; bottom: 26%; right: 30%; animation: float 8s ease-in-out infinite reverse; }
.composition .ring { position: absolute; bottom: 16%; right: 8%; width: 90px; height: 90px; border-radius: 50%; border: 1.5px solid var(--mint); }
.composition .ring::after { content: ""; position: absolute; inset: -1.5px; border-radius: 50%; border: 1.5px solid var(--mint); animation: pulsering 2.6s ease-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-16px); } }
@keyframes pulsering { 0% { transform: scale(1); opacity: 0.8; } 100% { transform: scale(1.7); opacity: 0; } }
@media (max-width: 900px) { .hero__inner { grid-template-columns: 1fr; } .composition { display: none; } }

/* Hero fading slider */
.hero__left { position: relative; }
.hero__actions { display: flex; align-items: center; gap: clamp(1rem, 3vw, 2rem); flex-wrap: wrap; margin-top: clamp(1.6rem, 3vw, 2.4rem); }
.hero__slider { position: relative; display: grid; }
.hero__slide { grid-area: 1 / 1; opacity: 0; visibility: hidden; transform: translateY(14px); transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1), visibility .8s; pointer-events: none; }
.hero__slide.is-active { opacity: 1; visibility: visible; transform: none; pointer-events: auto; }
.hero__controls { display: flex; gap: 0.5rem; align-items: center; }
.hero__dot { width: 28px; height: 5px; border-radius: 99px; background: var(--surface-line-strong); transition: width .45s ease, background .45s ease; }
.hero__dot:hover { background: var(--mint-dim); }
.hero__dot.is-active { width: 52px; background: var(--mint); box-shadow: 0 0 14px rgba(4, 229, 172, 0.5); }
.hero__scroll { position: absolute; bottom: 1.6rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.35rem; z-index: 3; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.22em; color: var(--text-faint); transition: color .3s; }
.hero__scroll:hover { color: var(--mint); }
.hero__scroll .chev { animation: scrollbounce 1.8s ease-in-out infinite; }
@keyframes scrollbounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(5px); } }

/* ---------- Brands marquee ---------- */
.marquee-strip { border-block: 1px solid var(--surface-line); padding-block: 1.6rem; overflow: hidden; position: relative; }
.marquee-strip::before, .marquee-strip::after { content: ""; position: absolute; top: 0; bottom: 0; width: 16%; z-index: 2; pointer-events: none; }
.marquee-strip::before { left: 0; background: linear-gradient(90deg, var(--ink), transparent); }
.marquee-strip::after { right: 0; background: linear-gradient(270deg, var(--ink), transparent); }
.marquee { display: flex; gap: 4rem; width: max-content; animation: marquee 32s linear infinite; }
.marquee-strip:hover .marquee { animation-play-state: paused; }
.marquee .logo { font-family: var(--font-display); font-size: 1.35rem; color: var(--text-faint); letter-spacing: 0.02em; opacity: 0.7; transition: opacity .3s, color .3s; white-space: nowrap; }
.marquee .logo:hover { color: var(--text); opacity: 1; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- Intro / Get to know us ---------- */
.intro__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.intro__title { font-family: var(--font-display); font-weight: 600; line-height: 1.05; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.4rem); margin: 1.2rem 0 1.4rem; }
.intro__sub { font-size: 0.95rem; line-height: 1.7; max-width: 54ch; margin-bottom: 2rem; color: var(--light-muted); }
.intro__sub .hl { color: var(--mint-dim); font-weight: 600; font-family: var(--font-mono); }
.intro__timeline { background: #fff; border: 1px solid rgba(11, 19, 43, 0.08); border-radius: calc(var(--radius) + 4px); padding: clamp(1.8rem, 3vw, 2.6rem); box-shadow: 0 30px 70px -45px rgba(11, 19, 43, 0.35); }
.timeline { position: relative; margin-top: 1.8rem; display: grid; gap: 1.7rem; padding-left: 0.2rem; }
.timeline::before { content: ""; position: absolute; left: 8px; top: 10px; bottom: 10px; width: 2px; background: linear-gradient(var(--mint), rgba(4, 229, 172, 0.12)); }
.timeline__item { position: relative; display: grid; grid-template-columns: auto 1fr; gap: 1.2rem; align-items: start; }
.timeline__item { transition: transform .35s cubic-bezier(.16,1,.3,1); }
.timeline__dot { width: 18px; height: 18px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 0 5px rgba(4, 229, 172, 0.16); margin-top: 5px; position: relative; z-index: 1; transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s ease; }
.timeline__content { transition: transform .35s cubic-bezier(.16,1,.3,1); }
.timeline__year { font-family: var(--font-display); font-size: 1.55rem; font-weight: 600; color: var(--light-ink); line-height: 1; transition: color .3s ease, transform .35s cubic-bezier(.16,1,.3,1); }
.timeline__content p { color: var(--light-muted); font-size: 0.95rem; margin-top: 0.35rem; transition: color .3s ease; }
.timeline__item:hover .timeline__dot { transform: scale(1.28); box-shadow: 0 0 0 6px rgba(4, 229, 172, 0.22), 0 0 18px rgba(4, 229, 172, 0.55); }
.timeline__item:hover .timeline__content { transform: translateX(6px); }
.timeline__item:hover .timeline__year { color: var(--mint-dim); }
.timeline__item:hover .timeline__content p { color: var(--light-ink); }
.timeline__item:last-child .timeline__dot::after { content: ""; position: absolute; inset: -1px; border-radius: 50%; border: 2px solid var(--mint); animation: pulsering 2.4s ease-out infinite; }
@media (prefers-reduced-motion: reduce) { .timeline__item:last-child .timeline__dot::after { animation: none; } }
@media (max-width: 860px) { .intro__grid { grid-template-columns: 1fr; } }

/* ---------- Statement (legacy) ---------- */
.statement { text-align: center; }
.statement .big { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.025em; line-height: 1.04; font-size: clamp(2.2rem, 5.5vw, 4.4rem); max-width: 16ch; margin: 1.4rem auto 0; }

/* ---------- Blueprint (expandable cards) ---------- */
.blueprint__steps { display: flex; flex-direction: column; gap: clamp(0.9rem, 1.6vw, 1.3rem); }
.bp-card { position: relative; display: flex; flex-direction: column; border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); background: linear-gradient(160deg, var(--ink-2), var(--ink)); overflow: hidden; transition: border-color .35s ease, box-shadow .35s ease; }
.bp-card__head, .bp-card__body { position: relative; z-index: 1; }
.bp-card__ghost { display: none; }
.bp-card:hover { border-color: var(--surface-line-strong); }
.bp-card.is-open { border-color: var(--mint); box-shadow: var(--shadow-glow); }
.bp-card__head { width: 100%; display: flex; flex-direction: column; gap: clamp(1.1rem, 2vw, 1.6rem); padding: clamp(1.4rem, 1.8vw, 1.8rem); background: transparent; border: 0; color: inherit; text-align: left; cursor: pointer; font: inherit; }
.bp-card__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.bp-card__chip { flex: none; width: 46px; height: 46px; border-radius: 13px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; transition: transform .4s ease; }
.bp-card.is-open .bp-card__chip, .bp-card__head:hover .bp-card__chip { transform: rotate(-8deg) scale(1.05); }
.bp-card__heading { display: flex; flex-direction: column; gap: 0.3rem; min-width: 0; }
.bp-card__idx { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; color: var(--text-faint); }
.bp-card__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 1.6vw, 1.6rem); line-height: 1.1; color: var(--text); letter-spacing: -0.01em; white-space: nowrap; }
.bp-card__toggle { flex: none; width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--surface-line-strong); display: grid; place-items: center; color: var(--text); transition: transform .5s cubic-bezier(.16,1,.3,1), background .35s ease, color .35s ease, border-color .35s ease; }
.bp-card__head:hover .bp-card__toggle { border-color: var(--mint); color: var(--mint); }
.bp-card.is-open .bp-card__toggle { transform: rotate(135deg); background: var(--mint); color: #0b132b; border-color: var(--mint); }
/* stacked accordion (mobile / tablet) */
.bp-card__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .5s cubic-bezier(.16,1,.3,1); }
.bp-card.is-open .bp-card__body { grid-template-rows: 1fr; }
.bp-card__bodyinner { overflow: hidden; padding-left: clamp(1.4rem, 1.8vw, 1.8rem); padding-right: clamp(1.4rem, 1.8vw, 1.8rem); }
.bp-card__bodyinner p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; margin: 0 0 1.4rem; padding-top: 0.1rem; }
.bp-card__bodyinner .btn { margin-bottom: clamp(1.4rem, 1.8vw, 1.8rem); }
/* horizontal expanding panels (desktop) */
@media (min-width: 901px) {
	.blueprint__steps { flex-direction: row; align-items: stretch; height: clamp(270px, 26vw, 320px); }
	.bp-card { flex: 1 1 0; min-width: 0; transition: flex-grow .6s cubic-bezier(.16,1,.3,1), border-color .35s ease, box-shadow .35s ease; }
	.bp-card.is-open { flex-grow: 2.6; }
	.bp-card__head { flex: 0 0 auto; }
	.bp-card__body { display: flex; flex: 1 1 auto; min-height: 0; }
	.bp-card__bodyinner { height: 100%; min-width: 0; display: flex; flex-direction: column; align-items: flex-start; padding-bottom: clamp(1.4rem, 1.8vw, 1.8rem); opacity: 0; transition: opacity .35s ease; }
	.bp-card.is-open .bp-card__bodyinner { opacity: 1; transition-delay: .2s; }
	.bp-card__bodyinner p { margin: 0; }
	.bp-card__bodyinner .btn { margin-top: 1.4rem; margin-bottom: 0; white-space: nowrap; }
	.bp-card__ghost { display: block; position: absolute; right: clamp(0.6rem, 1.4vw, 1.2rem); bottom: clamp(-0.4rem, 0.4vw, 0.4rem); z-index: 0; font-family: var(--font-display); font-weight: 600; font-size: clamp(4.5rem, 8vw, 7rem); line-height: 1; color: transparent; -webkit-text-stroke: 1px var(--surface-line-strong); pointer-events: none; opacity: 1; transition: opacity .35s ease; }
	.bp-card.is-open .bp-card__ghost { opacity: 0; }
}
/* Step cards (reused on About page) */
.step-card { position: relative; padding: clamp(1.7rem, 2.8vw, 2.4rem); border-radius: calc(var(--radius) + 4px); border: 1px solid var(--surface-line); background: linear-gradient(150deg, var(--ink-2), var(--ink)); min-height: 220px; display: flex; flex-direction: column; transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease; overflow: hidden; }
.step-card:hover { transform: translateY(-4px); border-color: var(--mint); box-shadow: var(--shadow-glow); }
.step-card__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: auto; }
.step-card__idx { font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.1em; color: var(--text-faint); }
.step-card__chip { width: 46px; height: 46px; border-radius: 13px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; transition: transform .4s ease; }
.step-card:hover .step-card__chip { transform: rotate(-8deg) scale(1.05); }
.step-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.7rem); margin: 1.4rem 0 0.45rem; }
.step-card p { color: var(--text-muted); font-size: 0.95rem; }
@media (max-width: 820px) { .step-card { min-height: auto; } }

/* ---------- What we do — pinned horizontal scroll (white) ---------- */
.whatwedo { position: relative; background: var(--light); }
.whatwedo__sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; flex-direction: column; justify-content: center; padding-block: clamp(4rem, 8vh, 5.5rem) clamp(1rem, 2vh, 2rem); }
.whatwedo .section-header h2 { font-size: clamp(2rem, 4.5vw, 3.4rem); margin: 0.7rem 0 0; }
.whatwedo__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; margin-bottom: clamp(1rem, 2.5vh, 1.8rem); }
.whatwedo__scrollbar { display: flex; align-items: center; gap: 1rem; padding-bottom: 0.4rem; }
.whatwedo__scrollbar .lbl, .whatwedo__scrollbar .count { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--light-muted); }
.whatwedo__scrollbar .count { color: var(--mint-dim); }
.whatwedo__scrollbar .track { position: relative; width: clamp(120px, 16vw, 240px); height: 2px; background: rgba(11, 19, 43, 0.14); border-radius: 2px; overflow: hidden; }
.whatwedo__scrollbar .track i { position: absolute; left: 0; top: 0; height: 100%; width: 15%; background: var(--gradient-ember); border-radius: 2px; transition: width .12s linear; }
.whatwedo__viewport { overflow: hidden; }
.whatwedo__track { display: flex; gap: 1.4rem; padding-inline: var(--gutter); width: max-content; will-change: transform; }
.wd-card { position: relative; overflow: hidden; width: min(86vw, 410px); flex: 0 0 auto; border-radius: calc(var(--radius) + 6px); background: #fff; border: 1px solid rgba(11, 19, 43, 0.08); box-shadow: 0 30px 60px -45px rgba(11, 19, 43, 0.3); padding: clamp(1.6rem, 2.4vw, 2.2rem); min-height: clamp(340px, 56vh, 560px); display: flex; flex-direction: column; transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease; }
.wd-card:hover { transform: translateY(-5px); border-color: rgba(4, 229, 172, 0.5); box-shadow: 0 36px 70px -40px rgba(4, 229, 172, 0.4); }
.wd-card__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.1rem; }
.wd-card__idx { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--light-muted); }
.wd-card__chip { width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; flex: 0 0 auto; transition: transform .4s ease; }
.wd-card:hover .wd-card__chip { transform: rotate(-6deg) scale(1.05); }
.wd-card__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.75rem); line-height: 1.1; color: var(--light-ink); margin-bottom: 0.55rem; }
.wd-card__desc { color: var(--light-muted); font-size: 0.95rem; line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.wd-card__face { display: flex; flex-direction: column; flex: 1; }
.wd-card__hint { margin-top: auto; padding-top: 1.1rem; display: inline-flex; align-items: center; gap: 0.45rem; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--mint-dim); transition: opacity .3s ease; }
.wd-card:hover .wd-card__hint { opacity: 0; }
.wd-card__overlay { position: absolute; inset: 0; padding: clamp(1.4rem, 2vw, 1.9rem); background: var(--ink); color: #fff; display: flex; flex-direction: column; opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity .4s ease, transform .5s cubic-bezier(.16,1,.3,1); }
.wd-card:hover { border-color: var(--ink); }
.wd-card:hover .wd-card__overlay { opacity: 1; transform: none; pointer-events: auto; }
.wd-card__overlay .wd-card__top { margin-bottom: 1rem; }
.wd-card__overlay .wd-card__idx { color: rgba(255, 255, 255, 0.5); }
.wd-card__overlay .wd-card__chip { background: rgba(4, 229, 172, 0.18); color: var(--mint); }
.wd-card__otitle { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.75rem); line-height: 1.1; color: #fff; margin-bottom: 0.9rem; }
.wd-card__overlay-label { display: block; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mint); margin-bottom: 0.9rem; }
.wd-card__list { display: flex; flex-wrap: wrap; gap: 0.7rem 1rem; align-items: flex-start; }
.wd-card__list li { display: flex; align-items: flex-start; gap: 0.55rem; font-size: 0.95rem; line-height: 1.3; color: rgba(255, 255, 255, 0.88); }
.wd-card__list .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 8px rgba(4, 229, 172, 0.7); flex: 0 0 auto; margin-top: 0.4em; }
@media (hover: none) {
	.wd-card__hint { display: none; }
	.wd-card__overlay { position: static; opacity: 1; transform: none; pointer-events: auto; margin-top: 1.2rem; border-radius: 14px; }
	.wd-card__overlay .wd-card__top, .wd-card__otitle { display: none; }
}
.whatwedo__swipe { display: none; }
@media (max-width: 820px) {
	.whatwedo { height: auto !important; }
	.whatwedo__sticky { position: static; height: auto; padding-block: clamp(3rem, 6vw, 6rem); }
	.whatwedo__viewport { overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
	.whatwedo__viewport::-webkit-scrollbar { display: none; }
	.whatwedo__track { transform: none !important; }
	.whatwedo__scrollbar { display: none; }
	.whatwedo__head { display: block; }
	.wd-card { height: auto; }
	.whatwedo__swipe { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 1rem; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mint-dim); }
	.whatwedo__swipe .icon { animation: swipenudge 1.4s ease-in-out infinite; }
}
@keyframes swipenudge { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(6px); } }

/* Core values — dark variant + grid */
.whatwedo--dark { background: var(--ink); }
.whatwedo--dark .section-header h2 { color: var(--text); }
.values__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--surface-line); border: 1px solid var(--surface-line); border-radius: var(--radius); overflow: hidden; }
.value-card { background: var(--ink); padding: clamp(1.7rem, 2.6vw, 2.4rem); min-height: 250px; display: flex; flex-direction: column; transition: background .35s ease; }
.value-card:hover { background: var(--ink-2); }
.value-card__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: clamp(1.6rem, 3vw, 2.4rem); }
.value-card__chip { width: 46px; height: 46px; border-radius: 12px; border: 1px solid var(--surface-line-strong); color: var(--mint); display: grid; place-items: center; transition: border-color .35s ease, background .35s ease; }
.value-card:hover .value-card__chip { border-color: var(--mint); background: var(--mint-soft); }
.value-card__badge { font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.1em; color: var(--text-faint); }
.value-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.35rem, 2.2vw, 1.8rem); margin-bottom: 0.55rem; }
.value-card p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; min-height: 4.4em; }
.value-card__rule { margin-top: 1.5rem; width: 34px; height: 2px; border-radius: 2px; background: var(--surface-line-strong); transition: width .45s cubic-bezier(.16,1,.3,1), background .45s ease, box-shadow .45s ease; }
.value-card:hover .value-card__rule { width: 84px; background: var(--mint); box-shadow: 0 0 12px rgba(4, 229, 172, 0.55); }
@media (max-width: 900px) { .values__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .values__grid { grid-template-columns: 1fr; } }

/* ---------- Practices filmstrip (reused by qcore) ---------- */
.practices__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; position: relative; }
.practices__list { position: sticky; top: 120px; display: flex; flex-direction: column; gap: 0.2rem; }
.practice { display: flex; align-items: baseline; gap: 1rem; padding: 0.7rem 0; cursor: pointer; color: var(--text-faint); transition: color .3s; border-bottom: 1px solid var(--surface-line); }
.practice:hover, .practice.is-active { color: var(--text); }
.practice .num { font-family: var(--font-mono); font-size: 0.72rem; }
.practice h3 { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 600; }
.practice.is-active h3 { color: var(--mint); }
.practices__panels { position: relative; }
.practice-panel { display: none; animation: fadepanel .5s cubic-bezier(.16,1,.3,1); }
.practice-panel.is-active { display: block; }
@keyframes fadepanel { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.practice-panel .feature { position: relative; border-radius: var(--radius); padding: 2.2rem; overflow: hidden; background: radial-gradient(circle at 0% 0%, var(--mint-soft), transparent 60%), var(--ink-2); border: 1px solid var(--surface-line-strong); }
.practice-panel .feature .chip { width: 48px; height: 48px; border-radius: 13px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; margin-bottom: 1.4rem; transition: transform .4s; }
.practice-panel .feature:hover .chip { transform: rotate(-8deg) scale(1.05); }
.practice-panel .feature h4 { font-family: var(--font-display); font-size: 1.7rem; font-weight: 600; margin-bottom: 0.5rem; }
.practice-panel .feature p { color: var(--text-muted); }
.practice-panel .sub-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1rem; }
.practice-panel .sub-grid .mini { padding: 1.3rem; border-radius: var(--radius-sm); border: 1px solid var(--surface-line); background: var(--ink-2); }
.practice-panel .sub-grid .mini h5 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 600; margin-bottom: 0.3rem; }
.practice-panel .sub-grid .mini p { font-size: 0.85rem; color: var(--text-muted); }
.practices__ghost { position: absolute; right: 0; bottom: -4%; font-size: clamp(8rem, 20vw, 16rem); z-index: 0; }
@media (max-width: 860px) { .practices__grid { grid-template-columns: 1fr; } .practices__list { position: static; } }

/* qcore — light filmstrip overrides */
.qcore .practice { color: var(--light-muted); border-bottom-color: rgba(11, 19, 43, 0.1); }
.qcore .practice:hover, .qcore .practice.is-active { color: var(--light-ink); }
.qcore .practice h3 { font-weight: 600; font-size: clamp(1.25rem, 2.1vw, 1.7rem); }
.qcore .practice.is-active h3 { color: var(--mint-dim); }
.qcore .practice-panel .feature { background: radial-gradient(circle at 0% 0%, rgba(4, 229, 172, 0.10), transparent 60%), #fff; border: 1px solid rgba(11, 19, 43, 0.1); box-shadow: 0 30px 60px -45px rgba(11, 19, 43, 0.3); }
.qcore .practice-panel .feature .chip { background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); }
.qcore .practice-panel .feature h4 { color: var(--light-ink); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.6rem); }
.qcore .practice-panel .feature p { color: var(--light-muted); }
.qcore .practice-panel .sub-grid .mini { background: var(--light); border-color: rgba(11, 19, 43, 0.08); }
.qcore .practice-panel .sub-grid .mini h5 { color: var(--light-ink); font-weight: 600; font-size: 1.05rem; }
.qcore .practice-panel .sub-grid .mini p { color: var(--light-muted); }
.qcore .practices__ghost { -webkit-text-stroke: 1px rgba(11, 19, 43, 0.09); }

/* ---------- How we work loop ---------- */
.howwework { position: relative; overflow: hidden; padding-block: clamp(3.5rem, 8vw, 7rem); background: var(--ink); }
.howwework__head { text-align: center; margin-bottom: clamp(2rem, 5vw, 3.5rem); }
.howwework__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.4rem); line-height: 1.05; margin-top: 1rem; }
.loop-rows { display: flex; flex-direction: column; gap: clamp(0.2rem, 1.5vw, 1rem); }
.loop-row { overflow: hidden; display: flex; justify-content: center; }
.loop-row__inner { white-space: nowrap; display: inline-flex; align-items: center; will-change: transform; }
.loop-word { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; color: var(--text); font-size: clamp(2rem, 6vw, 5rem); line-height: 1.15; padding-inline: 0.35em; }
.loop-sep { color: var(--mint); font-size: clamp(1rem, 3vw, 2.4rem); opacity: 0.8; }
.loop-row__inner--faded { font-style: italic; opacity: 0.3; }
.loop-row__inner--faded .loop-word { font-style: italic; }
@media (prefers-reduced-motion: reduce) { .loop-row { justify-content: flex-start; } }

/* ---------- Engagement options ---------- */
.engage { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.2rem, 2.5vw, 1.8rem); align-items: stretch; }
.engage-card { position: relative; display: flex; flex-direction: column; padding: clamp(1.9rem, 3vw, 2.8rem); border-radius: calc(var(--radius) + 8px); border: 1px solid rgba(11, 19, 43, 0.1); background: #fff; overflow: hidden; transition: transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s ease, border-color .4s ease; }
.engage-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--gradient-ember); transform: scaleX(0); transform-origin: left; transition: transform .5s cubic-bezier(.16,1,.3,1); z-index: 2; }
.engage-card:hover { transform: translateY(-6px); box-shadow: 0 40px 80px -40px rgba(11, 19, 43, 0.28); border-color: var(--mint-dim); }
.engage-card:hover::before { transform: scaleX(1); }
.engage-card__head { display: flex; align-items: center; gap: 0.85rem; margin-bottom: 1.6rem; }
.engage-card__chip { width: 46px; height: 46px; border-radius: 13px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; flex: none; }
.engage-card__tag { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mint-dim); }
.engage-card__badge { margin-left: auto; display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.4rem 0.75rem; border-radius: 999px; background: var(--gradient-ember); color: #0b132b; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; }
.engage-card__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.7rem, 3vw, 2.3rem); line-height: 1.05; letter-spacing: -0.01em; color: var(--light-ink); margin-bottom: 0.85rem; }
.engage-card__desc { color: var(--light-muted); font-size: 0.95rem; line-height: 1.6; max-width: 42ch; }
.engage-card__rule { display: block; height: 1px; background: linear-gradient(90deg, rgba(11, 19, 43, 0.14), transparent); margin: 1.7rem 0; }
.engage-card__list { display: grid; gap: 0.85rem; margin-bottom: 2rem; }
.engage-card__list li { display: flex; align-items: center; gap: 0.75rem; font-size: 0.95rem; color: var(--light-ink); }
.engage-card__check { width: 22px; height: 22px; border-radius: 50%; background: rgba(4, 229, 172, 0.16); color: var(--mint-dim); display: grid; place-items: center; flex: none; }
.engage-card__foot { margin-top: auto; display: flex; flex-direction: column; gap: 0.85rem; align-items: flex-start; }
.engage-card__cta { display: inline-flex; align-items: center; gap: 0.55rem; padding: 0.85rem 1.6rem; border-radius: 999px; font-weight: 600; font-size: 0.95rem; background: var(--light-ink); color: #fff; transition: transform .25s ease, box-shadow .3s ease; }
.engage-card__cta .icon { transition: transform .3s ease; }
.engage-card:hover .engage-card__cta { transform: translateY(-2px); box-shadow: 0 14px 30px -14px rgba(11, 19, 43, 0.5); }
.engage-card:hover .engage-card__cta .icon { transform: translateX(3px); }
.engage-card__best { font-size: 0.82rem; color: var(--light-muted); }
/* featured (dark) */
.engage-card.is-featured { background: linear-gradient(160deg, var(--ink-2), var(--ink)); border-color: transparent; box-shadow: 0 34px 70px -42px rgba(4, 229, 172, 0.55); }
.engage-card.is-featured::after { content: ""; position: absolute; top: -28%; right: -18%; width: 55%; height: 65%; background: radial-gradient(circle, rgba(4, 229, 172, 0.22), transparent 65%); pointer-events: none; }
.engage-card.is-featured > * { position: relative; z-index: 1; }
.engage-card.is-featured .engage-card__title { color: #fff; }
.engage-card.is-featured .engage-card__desc { color: rgba(226, 232, 240, 0.82); }
.engage-card.is-featured .engage-card__list li { color: rgba(226, 232, 240, 0.92); }
.engage-card.is-featured .engage-card__rule { background: linear-gradient(90deg, rgba(255, 255, 255, 0.2), transparent); }
.engage-card.is-featured .engage-card__chip { background: rgba(4, 229, 172, 0.18); color: var(--mint); }
.engage-card.is-featured .engage-card__check { background: rgba(4, 229, 172, 0.22); color: var(--mint); }
.engage-card.is-featured .engage-card__cta { background: var(--gradient-ember); color: #0b132b; }
.engage-card.is-featured .engage-card__best { color: rgba(148, 163, 184, 0.95); }
.engage-card.is-featured:hover { box-shadow: 0 46px 90px -42px rgba(4, 229, 172, 0.62); }
@media (max-width: 760px) { .engage { grid-template-columns: 1fr; } }

/* ---------- Industries (home) ---------- */
.industries__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.industry { position: relative; padding: 1.8rem; border-radius: var(--radius); border: 1px solid var(--surface-line); background: var(--ink-2); overflow: hidden; transition: transform .35s, border-color .35s; }
.industry:hover { transform: translateY(-4px); border-color: var(--mint); }
.industry .bignum { position: absolute; top: -0.6rem; right: 0.6rem; font-family: var(--font-display); font-size: 5rem; color: transparent; -webkit-text-stroke: 1px var(--surface-line); transition: -webkit-text-stroke-color .35s, color .35s; line-height: 1; }
.industry:hover .bignum { color: var(--mint-soft); }
.industry__chip { width: 44px; height: 44px; border-radius: 12px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; margin-bottom: 1.4rem; position: relative; z-index: 1; }
.industry h3 { font-family: var(--font-display); font-size: clamp(1.3rem, 2.2vw, 1.7rem); font-weight: 600; margin-bottom: 0.4rem; position: relative; z-index: 1; }
.industry p { color: var(--text-muted); font-size: 0.95rem; margin-bottom: 1.2rem; position: relative; z-index: 1; }
.industry__link { display: inline-flex; align-items: center; gap: 0.4rem; font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--mint); position: relative; z-index: 1; }
.industry__link .icon { transition: transform .3s; }
.industry:hover .industry__link .icon { transform: translate(3px,-3px); }
@media (max-width: 880px) { .industries__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .industries__grid { grid-template-columns: 1fr; } }

/* ---------- Brands wall ---------- */
.brandwall { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(0.8rem, 1.6vw, 1.3rem); }
.brand-card { position: relative; overflow: hidden; display: flex; flex-direction: column; gap: 0.65rem; padding: clamp(1.4rem, 2.2vw, 1.9rem); border-radius: calc(var(--radius) + 2px); border: 1px solid rgba(11, 19, 43, 0.1); background: #fff; transition: transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s ease, border-color .4s ease; }
.brand-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--bc); transform: scaleX(0); transform-origin: left; transition: transform .5s cubic-bezier(.16,1,.3,1); }
.brand-card::after { content: ""; position: absolute; top: -40%; right: -30%; width: 60%; height: 80%; border-radius: 50%; background: var(--bc); opacity: 0; filter: blur(40px); transition: opacity .45s ease; pointer-events: none; }
.brand-card:hover { transform: translateY(-6px); border-color: var(--bc); box-shadow: 0 26px 50px -28px var(--bc); }
.brand-card:hover::before { transform: scaleX(1); }
.brand-card:hover::after { opacity: 0.14; }
.brand-card__mark { position: relative; z-index: 1; width: 36px; height: 36px; border-radius: 10px; background: var(--bc); display: grid; place-items: center; transition: transform .4s ease; }
.brand-card__mark::after { content: ""; width: 13px; height: 13px; border-radius: 50%; background: #fff; opacity: 0.92; }
.brand-card:hover .brand-card__mark { transform: rotate(-8deg) scale(1.08); }
.brand-card__name { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 700; font-size: clamp(1.05rem, 1.8vw, 1.35rem); line-height: 1.1; letter-spacing: -0.01em; color: var(--light-ink); margin-top: 0.2rem; }
.brand-card__tag { position: relative; z-index: 1; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--light-muted); }
@media (max-width: 760px) { .brandwall { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Stats counters ---------- */
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: left; }
.stat-block { padding: 1.6rem 0; border-top: 1px solid var(--surface-line-strong); }
.stat-block .val { font-family: var(--font-display); font-size: clamp(2.6rem, 6vw, 4rem); font-weight: 600; line-height: 1; color: var(--text); }
.stat-block .val .suffix { color: var(--mint); }
.stat-block .lbl { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); margin-top: 0.8rem; }
@media (max-width: 760px) { .stats__grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Schedule / Contact ---------- */
.schedule__card { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 5vw, 4rem); padding: clamp(2rem, 5vw, 4.5rem); border-radius: calc(var(--radius) + 6px); overflow: hidden; position: relative; background: radial-gradient(circle at 100% 0%, rgba(4, 229, 172, 0.12), transparent 55%), #f8fafc; }
.section-lighter .schedule__card { border: 1px solid rgba(4, 229, 172, 0.25); box-shadow: 0 40px 90px -50px rgba(4, 229, 172, 0.4); }
.schedule__pitch h2 { font-family: var(--font-display); font-size: clamp(2rem, 4.5vw, 3.4rem); font-weight: 600; line-height: 1.05; color: var(--light-ink); }
.schedule__pitch h2 .serif-i { color: var(--mint-dim); }
.schedule__pitch p { color: var(--light-muted); font-size: 0.95rem; margin: 1.2rem 0 2rem; max-width: 36ch; }
.schedule__meta { display: grid; gap: 1rem; }
.schedule__meta a, .schedule__meta div { display: flex; align-items: center; gap: 0.8rem; color: var(--light-ink); font-size: 0.95rem; }
.schedule__meta .icon { width: 40px; height: 40px; padding: 0.6rem; border-radius: 11px; background: rgba(4, 229, 172, 0.16); color: var(--mint-dim); flex: 0 0 auto; }
.form { display: grid; gap: 1.4rem; }
.field { position: relative; }
.field input, .field textarea { width: 100%; padding: 0.9rem 0; background: transparent; border: none; border-bottom: 1.5px solid rgba(71, 85, 105, 0.3); color: var(--light-ink); font-family: var(--font-body); font-size: 1rem; transition: border-color .3s; }
.field textarea { resize: vertical; min-height: 70px; }
.field label { position: absolute; left: 0; top: 0.9rem; color: var(--light-muted); pointer-events: none; transition: transform .3s, font-size .3s, color .3s; transform-origin: left; }
.field input:focus, .field textarea:focus { outline: none; border-bottom-color: var(--mint-dim); }
.field input:focus + label, .field input:not(:placeholder-shown) + label, .field textarea:focus + label, .field textarea:not(:placeholder-shown) + label { transform: translateY(-1.4rem) scale(0.78); color: var(--mint-dim); }
.form .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.form .btn-primary { justify-self: start; align-self: start; margin-top: 0.6rem; padding: 0.72rem 1.7rem; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em; }
@media (max-width: 820px) { .schedule__card { grid-template-columns: 1fr; } .form .field-row { grid-template-columns: 1fr; } }

/* ---------- Footer ---------- */
.site-footer { position: relative; background: var(--ink); border-top: 1px solid var(--surface-line); padding-top: clamp(3.5rem, 7vw, 5.5rem); padding-bottom: 0; overflow: hidden; }

/* Top — brand + newsletter */
.ftr-top { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.ftr-logo { display: inline-flex; flex-direction: column; line-height: 0.9; }
.ftr-logo__mark { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.4rem, 5vw, 3.4rem); color: rgba(148, 163, 184, 0.32); letter-spacing: -0.01em; }
.ftr-logo__sub { font-family: var(--font-display); font-weight: 400; font-size: clamp(0.8rem, 1.4vw, 0.95rem); color: rgba(148, 163, 184, 0.32); letter-spacing: 0.18em; text-transform: uppercase; margin-top: 0.2rem; }
.ftr-logo__img { display: block; height: 56px; width: auto; }
.ftr-brand__tag { color: var(--text); font-size: clamp(1rem, 1.6vw, 1.2rem); margin-top: 1.4rem; max-width: 36ch; }
.ftr-news { justify-self: end; width: 100%; max-width: 560px; }
.ftr-news__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem, 1.8vw, 1.25rem); letter-spacing: 0.02em; text-transform: uppercase; color: var(--mint); margin-bottom: 1.3rem; }
.ftr-news__form { display: flex; align-items: stretch; }
.ftr-news__form input { flex: 1; min-width: 0; background: transparent; border: 1px solid var(--surface-line-strong); border-right: none; color: var(--text); font-family: var(--font-body); font-size: 0.95rem; padding: 0.9rem 1.2rem; transition: border-color .3s ease; }
.ftr-news__form input::placeholder { color: var(--text-faint); }
.ftr-news__form input:focus { outline: none; border-color: var(--mint); }
.ftr-news__btn { flex: 0 0 auto; background: var(--mint); color: var(--ink); font-family: var(--font-display); font-weight: 600; font-size: 0.82rem; letter-spacing: 0.06em; text-transform: uppercase; border: none; padding: 0 clamp(1.2rem, 2.5vw, 1.8rem); cursor: pointer; transition: background .3s ease; }
.ftr-news__btn:hover { background: #fff; }

.ftr-divider { height: 1px; background: var(--surface-line); margin: clamp(2rem, 4vw, 3rem) 0; }

/* Middle — columns */
.ftr-cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); }
.ftr-col__title { font-family: var(--font-display); font-weight: 600; font-size: 0.95rem; letter-spacing: 0.04em; text-transform: uppercase; color: rgba(148, 163, 184, 0.6); margin-bottom: 1.6rem; }
.ftr-office { font-style: normal; display: grid; gap: 1.1rem; }
.ftr-office__row { display: flex; align-items: flex-start; gap: 0.9rem; color: var(--text); font-size: 0.98rem; line-height: 1.5; }
.ftr-office__ico { flex: 0 0 auto; color: var(--text-muted); margin-top: 0.1rem; }
a.ftr-office__row:hover { color: var(--mint); }
a.ftr-office__row:hover .ftr-office__ico { color: var(--mint); }
.ftr-certs { display: grid; gap: 1rem; list-style: none; margin: 0; padding: 0; }
.ftr-certs li { position: relative; padding-left: 1.4rem; color: var(--text); font-size: 0.95rem; }
.ftr-certs li::before { content: ""; position: absolute; left: 0; top: 0.45em; border-left: 6px solid var(--mint); border-top: 4px solid transparent; border-bottom: 4px solid transparent; }
.ftr-social { display: flex; gap: 0.7rem; }
.ftr-social a { width: 44px; height: 44px; border-radius: 8px; border: 1px solid var(--surface-line-strong); display: grid; place-items: center; color: var(--text); transition: border-color .3s ease, color .3s ease, transform .3s ease, background .3s ease; }
.ftr-social a:hover { border-color: var(--mint); color: var(--mint); background: rgba(4, 229, 172, 0.08); transform: translateY(-3px); }

/* Bottom */
.ftr-bottom { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding-block: 1.6rem clamp(2rem, 4vw, 2.5rem); }
.ftr-bottom small { color: var(--text-muted); font-size: 0.85rem; }
.ftr-bottom__meta { color: var(--text-faint); }
@media (max-width: 860px) { .ftr-top { grid-template-columns: 1fr; } .ftr-news { justify-self: start; max-width: none; } .ftr-cols { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .ftr-cols { grid-template-columns: 1fr; } }

/* =================================================================
   ABOUT PAGE
   ================================================================= */
.about-hero { position: relative; min-height: 90vh; display: flex; align-items: center; text-align: center; overflow: hidden; padding-block: 9rem 4rem; background: var(--ink); }
.about-hero__bg .glow { position: absolute; top: 42%; left: 50%; transform: translate(-50%, -50%); width: 62vw; height: 62vw; background: var(--gradient-radial-ember); opacity: 0.4; }
.about-hero__bg .grid { position: absolute; inset: 0; opacity: 0.4; background-image: linear-gradient(var(--surface-line) 1px, transparent 1px), linear-gradient(90deg, var(--surface-line) 1px, transparent 1px); background-size: 64px 64px; -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 45%, #000, transparent 75%); mask-image: radial-gradient(ellipse 70% 60% at 50% 45%, #000, transparent 75%); }
.about-hero__inner { position: relative; z-index: 2; }
.about-hero__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.04; font-size: clamp(2.2rem, 5vw, 3.9rem); margin: 1.4rem auto; max-width: 14ch; }
.about-hero__title .muted { color: var(--text-faint); }
.about-hero__sub { color: var(--text-muted); font-size: clamp(1rem, 1.4vw, 1.2rem); max-width: 60ch; margin: 0 auto 2rem; }
.about-hero__ctas { display: flex; gap: 0.9rem; justify-content: center; flex-wrap: wrap; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.about-pills { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.about-pill { background: var(--surface); border: 1px solid var(--surface-line-strong); border-radius: 16px; padding: 1rem 1.4rem; backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); text-align: left; box-shadow: var(--shadow-elevated); }
.about-pill b { display: block; font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; color: var(--text); }
.about-pill span { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.about-pill.p1 { transform: translateY(10px); } .about-pill.p2 { transform: translateY(-12px); } .about-pill.p3 { transform: translateY(6px); }
@media (max-width: 680px) { .about-pill { transform: none !important; } }
.whoweare__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.whoweare__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(2rem, 4.5vw, 3.4rem); margin: 1.2rem 0 1.8rem; }
.whoweare__right { display: grid; gap: 1.2rem; padding-top: 0.5rem; }
.whoweare__right p { color: var(--light-muted); font-size: 0.95rem; line-height: 1.7; }
@media (max-width: 820px) { .whoweare__grid { grid-template-columns: 1fr; } }
.qce-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
@media (max-width: 760px) { .qce-grid { grid-template-columns: 1fr; } }
.mv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.4rem, 3vw, 2.4rem); align-items: start; }
.mv-card { background: #fff; border: 1px solid rgba(11, 19, 43, 0.08); border-radius: calc(var(--radius) + 6px); padding: clamp(2rem, 4vw, 3rem); box-shadow: 0 30px 60px -45px rgba(11, 19, 43, 0.3); will-change: transform; }
.mv-card[data-mv-dir="-1"] { margin-top: clamp(2rem, 6vw, 4.5rem); }
.mv-card__chip { width: 54px; height: 54px; border-radius: 14px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; margin-bottom: 1.4rem; }
.mv-card .eyebrow { margin-bottom: 1rem; }
.mv-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.5rem, 2.6vw, 2.1rem); line-height: 1.12; color: var(--light-ink); margin-bottom: 1rem; }
.mv-card p { color: var(--light-muted); line-height: 1.7; font-size: 0.95rem; }
@media (max-width: 760px) { .mv-grid { grid-template-columns: 1fr; } .mv-card[data-mv-dir="-1"] { margin-top: 0; } .mv-card { transform: none !important; } }
.quality-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.6rem, 3vw, 2.6rem) clamp(2rem, 5vw, 4rem); }
.sectors { border-top: 1px solid rgba(11, 19, 43, 0.1); }
.sector-row { display: grid; grid-template-columns: auto 1fr auto auto; gap: clamp(1rem, 3vw, 2.5rem); align-items: center; padding: clamp(1.2rem, 2.5vw, 1.8rem) 0; border-bottom: 1px solid rgba(11, 19, 43, 0.1); transition: padding-left .3s ease; }
.sector-row:hover { padding-left: 0.6rem; }
.sector-row__num { font-family: var(--font-mono); font-size: 0.8rem; color: var(--mint-dim); }
.sector-row__name { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.4vw, 2rem); color: var(--light-ink); }
.sector-row__tag { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light-muted); }
.sector-row__link { display: inline-flex; align-items: center; gap: 0.4rem; font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--mint-dim); white-space: nowrap; }
.sector-row__link .icon { transition: transform .3s ease; }
.sector-row:hover .sector-row__link .icon { transform: translate(3px, -3px); }
@media (max-width: 680px) { .sector-row { grid-template-columns: auto 1fr; row-gap: 0.4rem; } .sector-row__tag, .sector-row__link { grid-column: 2; } }
.about-certs .cert-marquee { overflow: hidden; padding-block: 0.55rem; position: relative; }
.about-certs .cert-marquee:first-of-type { margin-top: 1.5rem; }
.cert-track { display: flex; gap: 1rem; width: max-content; animation: marquee 30s linear infinite; }
.cert-track--rev { animation-direction: reverse; }
.cert-pill { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); border: 1px solid var(--surface-line); border-radius: 999px; padding: 0.7rem 1.4rem; white-space: nowrap; }
@media (prefers-reduced-motion: reduce) { .cert-track { animation: none; } }
.about-cta .container-x, .blogx-cta .container-x { text-align: center; position: relative; z-index: 2; }
.about-cta__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.3rem); margin: 1rem auto 1.2rem; }
.about-cta__sub { color: var(--text-muted); max-width: 52ch; margin: 0 auto 2rem; font-size: 0.95rem; }
.about-cta__actions { display: flex; gap: 0.9rem; justify-content: center; flex-wrap: wrap; }
/* zigzag timeline (about/competency) */
.timeline-zz { position: relative; display: grid; gap: clamp(2.5rem, 6vw, 5rem); margin-top: clamp(2rem, 5vw, 4rem); }
.timeline-zz::before { content: ""; position: absolute; left: 50%; top: 0.4rem; bottom: 0.4rem; width: 2px; transform: translateX(-50%); background: linear-gradient(var(--mint), rgba(4, 229, 172, 0.15)); }
.zz-step { display: grid; grid-template-columns: 1fr auto 1fr; align-items: start; gap: 0 clamp(1.5rem, 4vw, 3.5rem); }
.zz-step__dot { grid-column: 2; position: relative; z-index: 1; width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--mint); background: var(--light); margin-top: 0.3rem; box-shadow: 0 0 0 5px rgba(4, 229, 172, 0.12); }
.zz-step__dot::after { content: ""; position: absolute; inset: 4px; border-radius: 50%; background: var(--mint); }
.zz-step__num { display: block; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint-dim); margin-bottom: 0.8rem; }
.zz-step__title h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.35rem, 2.5vw, 1.95rem); line-height: 1.18; color: var(--light-ink); }
.zz-step__desc p { color: var(--light-muted); font-size: 0.95rem; line-height: 1.7; }
.zz-step--left .zz-step__title { grid-column: 1; grid-row: 1; text-align: right; }
.zz-step--left .zz-step__desc { grid-column: 3; grid-row: 1; text-align: left; }
.zz-step--right .zz-step__title { grid-column: 3; grid-row: 1; text-align: left; }
.zz-step--right .zz-step__desc { grid-column: 1; grid-row: 1; text-align: right; }
@media (max-width: 760px) {
	.timeline-zz::before { left: 8px; transform: none; }
	.zz-step { grid-template-columns: 18px 1fr; gap: 0 1.2rem; }
	.zz-step__dot { grid-column: 1; grid-row: 1; margin-top: 0.35rem; }
	.zz-step__title, .zz-step__desc { grid-column: 2 !important; text-align: left !important; }
	.zz-step__title { grid-row: 1 !important; margin-bottom: 0.9rem; }
	.zz-step__desc { grid-row: 2 !important; }
}

/* =================================================================
   COMPETENCY PAGE
   ================================================================= */
.comp-hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; padding-block: 8.5rem 4rem; background: var(--ink); }
.comp-hero__bg .grid { position: absolute; inset: 0; opacity: 0.5; background-image: linear-gradient(rgba(4, 229, 172, 0.18) 1px, transparent 1px), linear-gradient(90deg, rgba(4, 229, 172, 0.18) 1px, transparent 1px); background-size: 56px 56px; -webkit-mask-image: radial-gradient(ellipse 95% 85% at 62% 50%, #000, transparent 82%); mask-image: radial-gradient(ellipse 95% 85% at 62% 50%, #000, transparent 82%); }
.comp-hero__bg .glow { position: absolute; top: 50%; right: -8%; transform: translateY(-50%); width: 54vw; height: 54vw; background: var(--gradient-radial-ember); opacity: 0.5; }
.comp-hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; width: 100%; }
.comp-hero__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.06; font-size: clamp(2.2rem, 5vw, 3.9rem); margin: 1.2rem 0 1.4rem; max-width: 18ch; }
.comp-ul { position: relative; }
.comp-ul::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0.02em; height: 3px; border-radius: 3px; background: var(--mint); opacity: 0.85; }
.comp-hero__sub { color: var(--text-muted); font-size: clamp(1rem, 1.4vw, 1.2rem); max-width: 48ch; margin-bottom: 2.2rem; }
.comp-hero__ctas { display: flex; gap: 0.9rem; flex-wrap: wrap; margin-bottom: 2.6rem; }
.comp-hero__stats { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); }
.comp-hero__stats b { color: var(--mint); font-weight: 600; }
.comp-hero__stats .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--surface-line-strong); }
.comp-visual { position: relative; aspect-ratio: 1 / 0.92; perspective: 1200px; }
.comp-visual__inner { position: absolute; inset: 0; transform-style: preserve-3d; transition: transform .2s ease-out; }
.comp-lines { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.comp-node { position: absolute; transform: translate(-50%, -50%); display: inline-flex; align-items: center; gap: 0.55rem; white-space: nowrap; font-family: var(--font-display); font-size: clamp(0.82rem, 1vw, 1rem); color: #fff; background: rgba(7, 17, 28, 0.5); border: 1px solid rgba(4, 229, 172, 0.5); border-radius: 999px; padding: 0.6rem 1.15rem; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); box-shadow: 0 0 24px -6px rgba(4, 229, 172, 0.35), inset 0 0 0 1px rgba(4, 229, 172, 0.08); transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease; }
.comp-node .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 10px var(--mint); flex: 0 0 auto; }
.comp-node:hover { border-color: var(--mint); box-shadow: 0 0 32px -4px rgba(4, 229, 172, 0.6); }
.comp-node.n0 { animation: float 7s ease-in-out infinite; }
.comp-node.n1 { animation: float 8s ease-in-out infinite reverse; }
.comp-node.n2 { animation: float 6.5s ease-in-out infinite; }
.comp-node.n3 { animation: float 7.5s ease-in-out infinite reverse; }
.comp-node.n4 { animation: float 6s ease-in-out infinite; }
.comp-node.n5 { animation: float 8.5s ease-in-out infinite reverse; }
@media (max-width: 900px) { .comp-hero__inner { grid-template-columns: 1fr; } .comp-visual { display: none; } }
@media (max-width: 560px) { .comp-node { font-size: 0.78rem; padding: 0.5rem 0.85rem; } }
.comp-mean__grid { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.comp-mean__copy h2 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(2rem, 4.5vw, 3.4rem); margin: 1.1rem 0 1.3rem; }
.comp-mean__copy p { color: var(--light-muted); font-size: 0.95rem; max-width: 44ch; margin-bottom: 2rem; line-height: 1.7; }
.comp-mean__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(11, 19, 43, 0.1); border: 1px solid rgba(11, 19, 43, 0.1); border-radius: var(--radius); overflow: hidden; }
.mean-card { position: relative; overflow: hidden; background: #fff; padding: clamp(1.5rem, 2.4vw, 2rem); min-height: 190px; display: flex; flex-direction: column; transition: background .3s ease; }
.mean-card:hover { background: var(--light); }
.mean-card__top { display: flex; justify-content: space-between; align-items: center; margin-bottom: clamp(1.6rem, 3vw, 2.6rem); }
.mean-card__num { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.12em; color: var(--mint-dim); }
.mean-card__plus { color: var(--light-muted); transition: transform .35s ease, color .35s ease; }
.mean-card:hover .mean-card__plus { color: var(--mint-dim); transform: rotate(90deg); }
.mean-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--light-ink); margin-bottom: 0.5rem; }
.mean-card p { color: var(--light-muted); font-size: 0.95rem; line-height: 1.6; }
@media (max-width: 860px) { .comp-mean__grid { grid-template-columns: 1fr; } }
@media (max-width: 520px) { .comp-mean__cards { grid-template-columns: 1fr; } }
/* core services accordion + card */
.coreserv__head { display: grid; grid-template-columns: 1.4fr 0.8fr; gap: 2rem; align-items: end; margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.coreserv__head h2 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(2rem, 4.5vw, 3.4rem); margin-top: 1rem; }
.coreserv__intro { color: var(--text-muted); font-size: 0.95rem; max-width: 38ch; }
@media (max-width: 760px) { .coreserv__head { grid-template-columns: 1fr; align-items: start; } }
.coreserv__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.acc-item { border-top: 1px solid var(--surface-line); }
.acc-item:last-child { border-bottom: 1px solid var(--surface-line); }
.acc-item__head { display: flex; align-items: center; gap: 1rem; width: 100%; padding: clamp(1.1rem, 2.4vw, 1.7rem) 0; cursor: pointer; text-align: left; background: none; }
.acc-item__num { flex: 0 0 auto; font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.1em; color: var(--text-faint); }
.acc-item__title { flex: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.4vw, 1.9rem); color: var(--text-faint); transition: color .3s ease; }
.acc-item__head:hover .acc-item__title, .acc-item.is-open .acc-item__title { color: var(--text); }
.acc-item__icon { flex: 0 0 auto; width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--surface-line-strong); color: var(--text-muted); display: grid; place-items: center; transition: transform .4s cubic-bezier(.16,1,.3,1), border-color .3s ease, color .3s ease; }
.acc-item.is-open .acc-item__icon { transform: rotate(45deg); border-color: var(--mint); color: var(--mint); }
.acc-item__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .45s cubic-bezier(.16,1,.3,1); }
.acc-item.is-open .acc-item__body { grid-template-rows: 1fr; }
.acc-item__inner { overflow: hidden; min-height: 0; }
.acc-item__inner > p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.65; padding: 0.2rem 0 1.2rem; max-width: 60ch; }
.acc-item__tags { display: flex; flex-wrap: wrap; gap: 0.6rem; padding-bottom: 1.6rem; }
.acc-tag { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); border: 1px solid var(--surface-line-strong); border-radius: 999px; padding: 0.4rem 0.85rem; }
.coreserv__cardwrap { position: sticky; top: 110px; align-self: start; }
.cs-card { display: none; position: relative; overflow: hidden; border-radius: calc(var(--radius) + 6px); border: 1px solid var(--surface-line-strong); padding: clamp(1.6rem, 2.6vw, 2.2rem); background: radial-gradient(circle at 100% 0%, rgba(4, 229, 172, 0.14), transparent 55%), var(--ink-2); }
.cs-card.is-active { display: block; animation: fadepanel .5s cubic-bezier(.16,1,.3,1); }
.cs-card__label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint); }
.cs-card__head { display: flex; align-items: center; gap: 1rem; margin: 1.1rem 0 1rem; }
.cs-card__chip { flex: 0 0 auto; width: 48px; height: 48px; border-radius: 13px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; }
.cs-card__head h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.25rem, 2.2vw, 1.6rem); line-height: 1.15; }
.cs-card__tagline { color: var(--text-muted); margin-bottom: 1.5rem; font-size: 0.95rem; }
.cs-card__pills { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.cs-pill { border: 1px solid var(--surface-line-strong); border-radius: 10px; padding: 0.7rem 1rem; font-size: 0.85rem; color: var(--text); background: rgba(11, 19, 43, 0.4); transition: border-color .3s ease; }
.cs-pill:hover { border-color: var(--mint); }
.cs-card__foot { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: 1.6rem; padding-top: 1.4rem; border-top: 1px solid var(--surface-line); }
.cs-card__owned { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); }
.cs-card__link { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--mint); font-weight: 600; font-size: 0.9rem; }
.cs-card__link .icon { transition: transform .3s ease; }
.cs-card__link:hover .icon { transform: translate(3px, -3px); }
@media (max-width: 900px) { .coreserv__grid { grid-template-columns: 1fr; } .coreserv__cardwrap { display: none; } }
/* standards bento */
.standards__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; grid-template-areas: "perf sec" "perf doc" "acc test"; }
.std-card { display: flex; flex-direction: column; border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); background: linear-gradient(155deg, var(--ink-2), var(--ink)); padding: clamp(1.6rem, 2.4vw, 2.2rem); min-height: 210px; transition: border-color .35s ease, box-shadow .35s ease, transform .35s ease; }
.std-card:hover { border-color: var(--mint); box-shadow: var(--shadow-glow); transform: translateY(-3px); }
.std-card.perf { grid-area: perf; } .std-card.sec { grid-area: sec; } .std-card.doc { grid-area: doc; }
.std-card.acc { grid-area: acc; } .std-card.test { grid-area: test; }
.std-card__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; }
.std-card__chip { flex: 0 0 auto; width: 44px; height: 44px; border-radius: 12px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; }
.std-card__metric { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); text-align: right; }
.std-card__body { margin-top: auto; }
.std-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.8rem); margin: 0 0 0.55rem; }
.std-card p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; max-width: 46ch; }
.std-card__foot { margin-top: auto; display: inline-flex; align-items: center; gap: 0.7rem; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); padding-top: 1.4rem; }
.std-card__foot i { width: 24px; height: 1px; background: var(--mint); flex: 0 0 auto; }
@media (max-width: 760px) { .standards__grid { grid-template-columns: 1fr; grid-template-areas: "perf" "sec" "doc" "acc" "test"; } .std-card.perf { min-height: 260px; } }
/* industries (competency) */
.comp-sectors__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.comp-sectors__copy h2 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(2rem, 4.5vw, 3.4rem); margin: 1.1rem 0 1.3rem; }
.comp-sectors__copy p { color: var(--light-muted); font-size: 0.95rem; max-width: 42ch; line-height: 1.7; }
.comp-sectors__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.sec-card { display: flex; flex-direction: column; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 4px); padding: clamp(1.4rem, 2.2vw, 1.9rem); min-height: 160px; transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease; }
.sec-card:hover { border-color: rgba(4, 229, 172, 0.55); box-shadow: 0 22px 44px -32px rgba(4, 229, 172, 0.45); transform: translateY(-3px); }
.sec-card.is-active { border-color: rgba(4, 229, 172, 0.55); box-shadow: 0 22px 44px -32px rgba(4, 229, 172, 0.35); }
.sec-card__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: auto; }
.sec-card__chip { width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; transition: background .3s ease, color .3s ease; }
.sec-card.is-active .sec-card__chip { background: var(--mint); color: var(--ink); }
.sec-card__num { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.1em; color: var(--light-muted); }
.sec-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--light-ink); margin-top: 1.4rem; }
.sec-card__link { display: inline-flex; align-items: center; gap: 0.4rem; margin-top: 0.7rem; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mint-dim); }
.sec-card__link .icon { transition: transform .3s ease; }
.sec-card:hover .sec-card__link .icon { transform: translate(3px, -3px); }
@media (max-width: 860px) { .comp-sectors__grid { grid-template-columns: 1fr; } }
@media (max-width: 480px) { .comp-sectors__cards { grid-template-columns: 1fr; } }
/* moving ticker */
.comp-ticker { position: relative; overflow: hidden; background: var(--ink-2); border-block: 1px solid var(--surface-line); padding-block: clamp(1.4rem, 3vw, 2.4rem); }
.comp-ticker::before, .comp-ticker::after { content: ""; position: absolute; top: 0; bottom: 0; width: 14%; z-index: 2; pointer-events: none; }
.comp-ticker::before { left: 0; background: linear-gradient(90deg, var(--ink-2), transparent); }
.comp-ticker::after { right: 0; background: linear-gradient(270deg, var(--ink-2), transparent); }
.comp-ticker__row { display: flex; align-items: center; gap: clamp(1.6rem, 3vw, 2.8rem); width: max-content; animation: marquee 42s linear infinite; }
.comp-ticker:hover .comp-ticker__row { animation-play-state: paused; }
.comp-ticker__word { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.01em; white-space: nowrap; font-size: clamp(1.5rem, 3.4vw, 2.9rem); color: var(--text-faint); transition: color .3s ease; }
.comp-ticker__word:hover { color: var(--text); }
.comp-ticker__sep { display: inline-flex; flex: 0 0 auto; color: var(--mint); }
@media (prefers-reduced-motion: reduce) { .comp-ticker__row { animation: none; } }

/* =================================================================
   CONSULTANCY / EMERGING PAGES
   ================================================================= */
.cons-hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; padding-block: 8.5rem 4rem; background: var(--ink); }
.cons-hero__bg .grid { position: absolute; inset: 0; opacity: 0.35; background-image: linear-gradient(var(--surface-line) 1px, transparent 1px), linear-gradient(90deg, var(--surface-line) 1px, transparent 1px); background-size: 62px 62px; -webkit-mask-image: radial-gradient(ellipse 80% 80% at 30% 45%, #000, transparent 80%); mask-image: radial-gradient(ellipse 80% 80% at 30% 45%, #000, transparent 80%); }
.cons-hero__bg .glow { position: absolute; top: 30%; left: -10%; width: 50vw; height: 50vw; background: var(--gradient-radial-ember); opacity: 0.3; }
.cons-hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; width: 100%; }
.cons-hero__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.04; font-size: clamp(2.2rem, 5vw, 3.9rem); margin: 1.4rem 0 1.6rem; max-width: 13ch; }
.cons-hero__sub { color: var(--text-muted); font-size: clamp(1rem, 1.4vw, 1.2rem); max-width: 50ch; line-height: 1.7; }
.cons-hero__cards { display: grid; gap: 1rem; }
.cons-phase { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: clamp(1rem, 2vw, 1.8rem); padding: clamp(1.1rem, 2vw, 1.5rem) clamp(1.2rem, 2.2vw, 1.7rem); border-radius: var(--radius); border: 1px solid var(--surface-line); background: linear-gradient(120deg, var(--ink-2), var(--ink)); transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease; }
.cons-phase.is-active { background: radial-gradient(circle at 0% 0%, rgba(4, 229, 172, 0.12), transparent 60%), var(--ink-2); border-color: var(--surface-line-strong); }
.cons-phase:hover { border-color: var(--mint); transform: translateY(-3px); box-shadow: var(--shadow-glow); }
.cons-phase__label { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); white-space: nowrap; }
.cons-phase__main h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); line-height: 1.1; }
.cons-phase__main p { color: var(--text-muted); font-size: 0.95rem; margin-top: 0.15rem; }
.cons-phase__arrow { color: var(--text-faint); transition: transform .3s ease, color .3s ease; }
.cons-phase:hover .cons-phase__arrow { color: var(--mint); transform: translate(3px, -3px); }
@media (max-width: 900px) { .cons-hero__inner { grid-template-columns: 1fr; } .cons-hero__cards { margin-top: 1rem; } }
@media (max-width: 480px) { .cons-phase { grid-template-columns: 1fr auto; } .cons-phase__label { grid-column: 1 / -1; } }
/* emerging hero cards */
.et-card { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 1rem; padding: clamp(0.85rem, 1.6vw, 1.15rem) clamp(1.1rem, 2vw, 1.4rem); border-radius: var(--radius); border: 1px solid var(--surface-line); background: linear-gradient(120deg, var(--ink-2), var(--ink)); transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease; }
.et-card:hover { border-color: var(--mint); transform: translateX(4px); box-shadow: var(--shadow-glow); }
.et-card__chip { width: 42px; height: 42px; border-radius: 11px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; }
.et-card__title { display: block; font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--text); line-height: 1.1; }
.et-card__sub { display: block; font-size: 0.8rem; color: var(--text-muted); margin-top: 0.1rem; }
.et-card__arrow { color: var(--text-faint); transition: transform .3s ease, color .3s ease; }
.et-card:hover .et-card__arrow { color: var(--mint); transform: translate(2px, -2px); }
.et-card.is-crit .et-card__chip { background: rgba(255, 95, 86, 0.16); color: #ff5f56; }
.et-card.is-crit:hover { border-color: #ff5f56; box-shadow: 0 0 0 1px rgba(255, 95, 86, 0.25), 0 12px 50px -12px rgba(255, 95, 86, 0.4); }
/* the premise sticky visual */
.cons-premise__grid { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
.cons-premise__visual { position: sticky; top: 100px; }
.northstar { position: relative; aspect-ratio: 1 / 1.04; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 8px); padding: clamp(1.6rem, 3vw, 2.4rem); overflow: hidden; box-shadow: 0 40px 80px -50px rgba(11, 19, 43, 0.35); display: flex; flex-direction: column; }
.northstar__label { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint-dim); position: relative; z-index: 2; }
.northstar__core { position: relative; flex: 1; display: grid; place-items: center; }
.northstar__glow { position: absolute; width: 85%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, rgba(4, 229, 172, 0.28), transparent 62%); }
.northstar__rings { position: absolute; width: 52%; aspect-ratio: 1; border-radius: 50%; border: 1px solid rgba(4, 229, 172, 0.25); box-shadow: 0 0 0 22px rgba(4, 229, 172, 0.07), 0 0 0 46px rgba(4, 229, 172, 0.04); }
.northstar__icon { position: relative; z-index: 2; width: 96px; height: 96px; border-radius: 50%; background: #fff; color: var(--mint-dim); display: grid; place-items: center; box-shadow: 0 16px 40px -14px rgba(4, 229, 172, 0.55); }
.northstar__text { position: relative; z-index: 2; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.6rem, 3vw, 2.4rem); line-height: 1.05; color: var(--light-ink); margin-top: auto; }
.northstar__badge { position: absolute; bottom: 9%; right: -3%; z-index: 3; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: 12px; padding: 0.7rem 1.1rem; box-shadow: 0 22px 44px -22px rgba(11, 19, 43, 0.35); }
.northstar__badge .lbl { display: block; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--light-muted); margin-bottom: 0.2rem; }
.northstar__badge b { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; color: var(--light-ink); }
.cons-premise__content h2 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(2rem, 4.5vw, 3.4rem); margin: 1.1rem 0 1.6rem; }
.cons-premise__content p { color: var(--light-muted); font-size: 0.95rem; line-height: 1.75; margin-bottom: 1.2rem; max-width: 58ch; }
.cons-premise__content p strong { color: var(--light-ink); font-weight: 600; }
.cons-premise__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; margin: 2rem 0; }
.cons-premise__stats > div { border-left: 1px solid rgba(11, 19, 43, 0.16); padding-left: 1rem; }
.cons-premise__stats b { display: block; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.9rem, 3.4vw, 2.6rem); line-height: 1; color: var(--light-ink); }
.cons-premise__stats span { display: block; margin-top: 0.5rem; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light-muted); }
.cons-premise__ctas { display: flex; gap: 0.9rem; flex-wrap: wrap; margin-top: 0.5rem; }
@media (max-width: 860px) { .cons-premise__grid { grid-template-columns: 1fr; } .cons-premise__visual { position: static; max-width: 460px; } .northstar__badge { right: 4%; } }
@media (max-width: 520px) { .cons-premise__stats { grid-template-columns: 1fr 1fr; } }
/* house rules */
.houserules__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--surface-line); border: 1px solid var(--surface-line); border-radius: var(--radius); overflow: hidden; }
.hr-card { position: relative; overflow: hidden; background: var(--ink); padding: clamp(1.8rem, 3.5vw, 3rem); min-height: 280px; display: flex; flex-direction: column; transition: background .4s ease; }
.hr-card__glow { position: absolute; inset: 0; opacity: 0; pointer-events: none; transition: opacity .5s ease; background: radial-gradient(circle at 42% 52%, rgba(4, 229, 172, 0.20), transparent 62%); }
.hr-card:hover .hr-card__glow { opacity: 1; }
.hr-card__ghost { position: absolute; top: -0.4rem; right: 0.6rem; z-index: 0; pointer-events: none; line-height: 1; font-family: var(--font-display); font-size: clamp(7rem, 14vw, 12rem); color: transparent; -webkit-text-stroke: 1px rgba(4, 229, 172, 0.07); transition: -webkit-text-stroke-color .4s ease; }
.hr-card:hover .hr-card__ghost { -webkit-text-stroke-color: rgba(4, 229, 172, 0.2); }
.hr-card__num { position: relative; z-index: 1; font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.12em; color: var(--mint); margin-bottom: clamp(1.4rem, 3vw, 2.2rem); }
.hr-card h3 { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.35rem, 2.4vw, 1.9rem); line-height: 1.15; margin-bottom: 0.8rem; }
.hr-card p { position: relative; z-index: 1; color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; max-width: 44ch; }
.hr-card__rule { position: relative; z-index: 1; margin-top: auto; padding-top: 1.6rem; width: 36px; height: 2px; background: transparent; border-radius: 2px; }
.hr-card__rule::after { content: ""; display: block; width: 36px; height: 2px; border-radius: 2px; background: var(--surface-line-strong); transition: width .4s cubic-bezier(.16,1,.3,1), background .4s ease; }
.hr-card:hover .hr-card__rule::after { width: 72px; background: var(--mint); box-shadow: 0 0 12px rgba(4, 229, 172, 0.55); }
@media (max-width: 640px) { .houserules__grid { grid-template-columns: 1fr; } }
/* core services engagement switcher */
.cons-core__grid { display: grid; grid-template-columns: 0.82fr 1.18fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.cons-core__tabs { display: grid; gap: 1rem; }
.eng-tab { display: grid; grid-template-columns: auto 1fr auto; gap: 0.9rem; align-items: start; text-align: left; cursor: pointer; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 4px); padding: clamp(1.2rem, 2vw, 1.6rem); transition: border-color .3s ease, box-shadow .3s ease, background .3s ease; }
.eng-tab.is-active { border-color: rgba(4, 229, 172, 0.55); box-shadow: 0 22px 44px -32px rgba(4, 229, 172, 0.4); background: radial-gradient(circle at 0% 0%, rgba(4, 229, 172, 0.08), transparent 55%), #fff; }
.eng-tab__chip { width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; transition: background .3s ease, color .3s ease; }
.eng-tab.is-active .eng-tab__chip { background: var(--mint); color: #fff; }
.eng-tab__label { display: block; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint-dim); }
.eng-tab__title { display: block; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--light-ink); margin: 0.25rem 0 0.4rem; }
.eng-tab__short { display: block; color: var(--light-muted); font-size: 0.95rem; line-height: 1.5; }
.eng-tab__arrow { color: var(--light-muted); transition: transform .3s ease, color .3s ease; }
.eng-tab.is-active .eng-tab__arrow, .eng-tab:hover .eng-tab__arrow { color: var(--mint-dim); transform: translate(2px, -2px); }
.cons-core__panels { position: relative; }
.eng-panel { display: none; position: relative; overflow: hidden; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 8px); padding: clamp(1.8rem, 3.5vw, 3rem); box-shadow: 0 40px 80px -55px rgba(11, 19, 43, 0.35); }
.eng-panel.is-active { display: block; animation: fadepanel .5s cubic-bezier(.16,1,.3,1); }
.eng-panel__ghost { position: absolute; top: 1.4rem; right: 1.6rem; z-index: 0; line-height: 1; font-family: var(--font-display); font-size: clamp(5rem, 10vw, 9rem); color: transparent; -webkit-text-stroke: 1px rgba(11, 19, 43, 0.07); pointer-events: none; }
.eng-panel__head { display: flex; align-items: center; gap: 0.8rem; margin-bottom: 1.2rem; position: relative; z-index: 1; }
.eng-panel__chip { width: 48px; height: 48px; border-radius: 13px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; }
.eng-panel__label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--light-muted); }
.eng-panel__title { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.7rem, 3.4vw, 2.5rem); line-height: 1.1; color: var(--light-ink); margin-bottom: 1.1rem; }
.eng-panel__tagline { position: relative; z-index: 1; display: block; font-family: var(--font-display); font-style: italic; color: var(--light-muted); font-size: 1.02rem; margin: -0.6rem 0 1.2rem; }
.eng-panel__desc { position: relative; z-index: 1; color: var(--light-muted); line-height: 1.75; margin-bottom: 1.8rem; max-width: 58ch; }
.eng-panel__walk { display: block; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint-dim); margin-bottom: 1rem; }
.eng-panel__list { display: grid; grid-template-columns: 1fr 1fr; gap: 0.9rem 1.5rem; margin-bottom: 1.8rem; }
.eng-panel__list li { display: flex; gap: 0.6rem; align-items: flex-start; font-size: 0.95rem; line-height: 1.4; color: var(--light-ink); }
.eng-panel__list .icon { color: var(--mint-dim); flex: 0 0 auto; margin-top: 2px; }
.eng-panel__tags { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 1.8rem; }
.eng-pill { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light-muted); border: 1px solid rgba(11, 19, 43, 0.15); border-radius: 999px; padding: 0.45rem 0.9rem; }
.et-core .eng-tab__short { display: none; }
.et-core .eng-tab.is-active .eng-tab__short { display: block; margin-top: 0.4rem; }
.et-core .eng-panel { background: radial-gradient(circle at 100% 0%, rgba(4, 229, 172, 0.12), transparent 45%), #fff; }
@media (max-width: 900px) { .cons-core__grid { grid-template-columns: 1fr; } }
@media (max-width: 520px) { .eng-panel__list { grid-template-columns: 1fr; } }
/* dark icon timeline */
.ctl { position: relative; display: grid; gap: clamp(2.5rem, 6vw, 4.5rem); margin-top: clamp(2rem, 5vw, 4rem); }
.ctl::before { content: ""; position: absolute; left: 50%; top: 1rem; bottom: 1rem; width: 1px; transform: translateX(-50%); background: linear-gradient(rgba(4, 229, 172, 0.45), rgba(4, 229, 172, 0.1)); }
.ctl-step { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 0 clamp(1.5rem, 4vw, 3.5rem); }
.ctl-step__node { grid-column: 2; position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 0.55rem; }
.ctl-step__num { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; color: var(--mint); }
.ctl-step__icon { width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--surface-line-strong); background: var(--ink); color: var(--mint); display: grid; place-items: center; box-shadow: 0 0 0 5px rgba(4, 229, 172, 0.06); }
.ctl-step__title h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.35rem, 2.5vw, 1.95rem); line-height: 1.18; color: var(--text); }
.ctl-step__card { background: var(--ink-2); border: 1px solid var(--surface-line); border-radius: var(--radius); padding: clamp(1.3rem, 2.2vw, 1.8rem); }
.ctl-step__card p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.65; }
.ctl-step--tleft .ctl-step__title { grid-column: 1; grid-row: 1; text-align: right; }
.ctl-step--tleft .ctl-step__card { grid-column: 3; grid-row: 1; }
.ctl-step--tright .ctl-step__title { grid-column: 3; grid-row: 1; text-align: left; }
.ctl-step--tright .ctl-step__card { grid-column: 1; grid-row: 1; }
@media (max-width: 760px) {
	.ctl::before { left: 23px; transform: none; }
	.ctl-step { grid-template-columns: 46px 1fr; gap: 0 1.2rem; align-items: start; }
	.ctl-step__node { grid-column: 1; grid-row: 1; }
	.ctl-step__title, .ctl-step__card { grid-column: 2 !important; text-align: left !important; }
	.ctl-step__title { grid-row: 1 !important; }
	.ctl-step__card { grid-row: 2 !important; margin-top: 1rem; }
}
/* deliverables list (light) */
.deliv__head { display: grid; grid-template-columns: 1.4fr 0.8fr; gap: 2rem; align-items: end; margin-bottom: clamp(2rem, 4vw, 3rem); padding-bottom: clamp(2rem, 4vw, 3rem); border-bottom: 1px solid rgba(11, 19, 43, 0.12); }
.deliv__badge { display: inline-block; background: var(--ink); color: #fff; font-size: 0.8rem; font-weight: 600; padding: 0.45rem 1.1rem; border-radius: 999px; }
.deliv__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.05; font-size: clamp(2rem, 4.5vw, 3.4rem); color: var(--light-ink); margin-top: 1.1rem; }
.deliv__title .hl { color: var(--mint-dim); font-style: italic; }
.deliv__intro { color: var(--light-muted); max-width: 40ch; font-size: 0.95rem; }
.deliv__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; }
.deliv__left { padding-right: clamp(1.5rem, 4vw, 3rem); }
.deliv__sub { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.12; font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--light-ink); margin-bottom: 1.1rem; }
.deliv__left p { color: var(--light-muted); max-width: 38ch; line-height: 1.7; font-size: 0.95rem; }
.deliv__list { border-left: 1px solid rgba(11, 19, 43, 0.12); }
.deliv-item { padding: clamp(1.4rem, 2.5vw, 2rem) clamp(1.5rem, 3vw, 2.5rem); border-bottom: 1px solid rgba(11, 19, 43, 0.12); transition: background .3s ease; }
.deliv-item:hover, .deliv-item.is-active { background: rgba(4, 229, 172, 0.07); }
.deliv-item h4 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.1rem, 1.8vw, 1.35rem); color: var(--light-ink); margin-bottom: 0.5rem; transition: color .3s ease; }
.deliv-item:hover h4, .deliv-item.is-active h4 { color: var(--mint-dim); }
.deliv-item p { color: var(--light-muted); font-size: 0.95rem; line-height: 1.6; }
@media (max-width: 760px) { .deliv__head { grid-template-columns: 1fr; align-items: start; } .deliv__grid { grid-template-columns: 1fr; } .deliv__left { padding-right: 0; margin-bottom: 1.5rem; } .deliv__list { border-left: none; border-top: 1px solid rgba(11, 19, 43, 0.12); } }
/* match the problem */
.matchp__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.mp-card { position: relative; overflow: hidden; display: flex; flex-direction: column; background: var(--ink-2); border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 6px); padding: clamp(1.6rem, 2.6vw, 2.2rem); min-height: 320px; transition: border-color .35s ease, transform .35s ease; }
.mp-card:hover { border-color: var(--surface-line-strong); transform: translateY(-3px); }
.mp-card__glow { position: absolute; bottom: -22%; right: -12%; width: 65%; height: 65%; border-radius: 50%; pointer-events: none; background: radial-gradient(circle, rgba(4, 229, 172, 0.20), transparent 65%); opacity: 0; transition: opacity .5s ease; }
.mp-card:hover .mp-card__glow { opacity: 1; }
.mp-card__chip { position: relative; z-index: 1; width: 44px; height: 44px; border-radius: 12px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; margin-bottom: clamp(1.5rem, 3vw, 2.2rem); }
.mp-card__label { position: relative; z-index: 1; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint); }
.mp-card__quote { position: relative; z-index: 1; font-family: var(--font-display); font-style: italic; font-size: clamp(1.2rem, 2vw, 1.5rem); line-height: 1.28; color: var(--text); margin: 0.7rem 0 1.4rem; }
.mp-card__foot { position: relative; z-index: 1; margin-top: auto; padding-top: 1.4rem; border-top: 1px solid var(--surface-line); display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.mp-card__start { display: block; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); margin-bottom: 0.35rem; }
.mp-card__service { font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem, 1.6vw, 1.2rem); color: var(--text); }
.mp-card__arrow { flex: 0 0 auto; width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--surface-line-strong); color: var(--text-muted); display: grid; place-items: center; transition: background .35s ease, color .35s ease, border-color .35s ease; }
.mp-card:hover .mp-card__arrow { background: var(--mint); color: var(--ink); border-color: var(--mint); box-shadow: 0 0 22px -4px rgba(4, 229, 172, 0.6); }
@media (max-width: 860px) { .matchp__grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }
/* industries context grid */
.ind-ctx__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(11, 19, 43, 0.1); border: 1px solid rgba(11, 19, 43, 0.1); border-radius: var(--radius); overflow: hidden; }
.ind-cell { position: relative; overflow: hidden; display: flex; align-items: center; gap: 1rem; background: #fff; padding: clamp(1.4rem, 2.5vw, 2rem); transition: background .3s ease; }
.ind-cell__glow { position: absolute; top: -40%; right: -18%; width: 55%; height: 90%; border-radius: 50%; pointer-events: none; background: radial-gradient(circle, rgba(4, 229, 172, 0.16), transparent 65%); opacity: 0; transition: opacity .4s ease; }
.ind-cell:hover .ind-cell__glow { opacity: 1; }
.ind-cell__chip { position: relative; z-index: 1; flex: 0 0 auto; width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; transition: background .3s ease, color .3s ease; }
.ind-cell:hover .ind-cell__chip { background: var(--mint); color: #fff; }
.ind-cell__body { position: relative; z-index: 1; }
.ind-cell h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--light-ink); margin-bottom: 0.3rem; }
.ind-cell__tags { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.02em; color: var(--light-muted); }
@media (max-width: 860px) { .ind-ctx__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .ind-ctx__grid { grid-template-columns: 1fr; } }

/* Emerging — alternating card timeline */
.etl { position: relative; display: grid; gap: clamp(1.8rem, 4vw, 3rem); margin-top: clamp(2rem, 5vw, 4rem); }
.etl::before { content: ""; position: absolute; left: 50%; top: 1rem; bottom: 1rem; width: 1px; transform: translateX(-50%); background: linear-gradient(rgba(4, 229, 172, 0.45), rgba(4, 229, 172, 0.1)); }
.etl-step { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 0 clamp(1.5rem, 4vw, 3rem); }
.etl-step__node { grid-column: 2; position: relative; z-index: 1; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--surface-line-strong); background: var(--ink); color: var(--mint); display: grid; place-items: center; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.04em; box-shadow: 0 0 0 5px rgba(4, 229, 172, 0.06); }
.etl-step__card { background: linear-gradient(150deg, var(--ink-2), var(--ink)); border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); padding: clamp(1.5rem, 2.5vw, 2.2rem); transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease; }
.etl-step__card:hover { border-color: var(--mint); transform: translateY(-3px); box-shadow: var(--shadow-glow); }
.etl-step__card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.7rem); margin-bottom: 0.7rem; }
.etl-step__card p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.65; }
.etl-step--right .etl-step__card { grid-column: 3; }
.etl-step--left .etl-step__card { grid-column: 1; }
/* left-rail variant — line left, all cards right */
.etl--rail::before { left: 19px; transform: none; }
.etl--rail .etl-step { grid-template-columns: 38px 1fr; gap: 0 clamp(1.2rem, 3vw, 2rem); align-items: start; }
.etl--rail .etl-step__node { grid-column: 1; }
.etl--rail .etl-step__card { grid-column: 2 !important; }
@media (max-width: 760px) {
	.etl::before { left: 19px; transform: none; }
	.etl-step { grid-template-columns: 38px 1fr; gap: 0 1.2rem; }
	.etl-step__node { grid-column: 1; }
	.etl-step__card { grid-column: 2 !important; }
}

/* Emerging — standards bento (light, corner brackets) */
.estd__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1.2rem; }
.estd-card:nth-child(1), .estd-card:nth-child(2) { grid-column: span 3; }
.estd-card:nth-child(3), .estd-card:nth-child(4), .estd-card:nth-child(5) { grid-column: span 2; }
.estd-card { position: relative; overflow: hidden; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 4px); padding: clamp(1.8rem, 3vw, 2.6rem); min-height: 220px; display: flex; flex-direction: column; transition: border-color .35s ease, box-shadow .35s ease, transform .35s ease; }
.estd-card:hover { border-color: rgba(4, 229, 172, 0.5); box-shadow: 0 30px 60px -45px rgba(4, 229, 172, 0.4); transform: translateY(-3px); }
.estd-card::before, .estd-card::after { content: ""; position: absolute; width: 14px; height: 14px; border-color: rgba(4, 229, 172, 0.45); z-index: 1; pointer-events: none; }
.estd-card::before { top: 14px; left: 14px; border-top: 1.5px solid; border-left: 1.5px solid; }
.estd-card::after { bottom: 14px; right: 14px; border-bottom: 1.5px solid; border-right: 1.5px solid; }
.estd-card__ghost { position: absolute; top: 0.8rem; right: 1.4rem; z-index: 0; line-height: 1; font-family: var(--font-display); font-size: clamp(4rem, 7vw, 6rem); color: transparent; -webkit-text-stroke: 1px rgba(11, 19, 43, 0.06); pointer-events: none; }
.estd-card__chip { position: relative; z-index: 1; width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; margin-bottom: clamp(1.5rem, 3vw, 2.4rem); }
.estd-card h3 { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--light-ink); margin-bottom: 0.6rem; }
.estd-card p { position: relative; z-index: 1; color: var(--light-muted); font-size: 0.95rem; line-height: 1.6; max-width: 48ch; }
.estd-card__rule { position: relative; z-index: 1; margin-top: auto; padding-top: 1.4rem; width: 34px; height: 2px; background: transparent; }
.estd-card__rule::after { content: ""; display: block; width: 34px; height: 2px; border-radius: 2px; background: var(--surface-line-strong); transition: width .4s ease, background .4s ease; }
.estd-card:hover .estd-card__rule::after { width: 72px; background: var(--mint-dim); }
@media (max-width: 860px) { .estd__grid { grid-template-columns: 1fr 1fr; } .estd-card { grid-column: auto !important; } }
@media (max-width: 540px) { .estd__grid { grid-template-columns: 1fr; } }

/* Emerging — in the wild (dark use-case grid) */
.wild__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.wild-card { border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); background: linear-gradient(155deg, var(--ink-2), var(--ink)); padding: clamp(1.6rem, 2.5vw, 2.2rem); transition: border-color .35s ease, box-shadow .35s ease, transform .35s ease; }
.wild-card:hover { border-color: var(--mint); box-shadow: var(--shadow-glow); transform: translateY(-3px); }
.wild-card__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.4rem; }
.wild-card__chip { width: 44px; height: 44px; border-radius: 12px; background: var(--mint-soft); color: var(--mint); display: grid; place-items: center; }
.wild-card__num { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.1em; color: var(--text-faint); }
.wild-card h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); margin-bottom: 1.2rem; }
.wild-card__list { display: grid; gap: 0.7rem; }
.wild-card__list li { display: flex; gap: 0.6rem; align-items: flex-start; font-size: 0.95rem; color: var(--text-muted); line-height: 1.4; }
.wild-card__list .spark { color: var(--mint); flex: 0 0 auto; margin-top: 1px; display: inline-flex; }
.wild-card__list .warn { color: var(--text-faint); flex: 0 0 auto; margin-top: 1px; display: inline-flex; }
.wild-card:hover .wild-card__list--warn .warn { color: var(--mint); }
@media (max-width: 880px) { .wild__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .wild__grid { grid-template-columns: 1fr; } }

/* Emerging — find your fit (IF / THEN matcher) */
.fyf__list { border: 1px solid rgba(11, 19, 43, 0.1); border-radius: var(--radius); overflow: hidden; background: #fff; box-shadow: 0 30px 60px -50px rgba(11, 19, 43, 0.4); }
.fyf-row { display: grid; grid-template-columns: auto 1fr auto; gap: clamp(1rem, 3vw, 2.5rem); align-items: center; padding: clamp(1.4rem, 2.5vw, 2rem) clamp(1.5rem, 3vw, 2.5rem); border-bottom: 1px solid rgba(11, 19, 43, 0.1); transition: background .3s ease; }
.fyf-row:last-child { border-bottom: none; }
.fyf-row:hover { background: rgba(4, 229, 172, 0.05); }
.fyf-row__num { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.1em; color: var(--mint-dim); }
.fyf-row__lbl { display: block; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--light-muted); margin-bottom: 0.4rem; }
.fyf-row__if p { font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem, 1.7vw, 1.3rem); color: var(--light-ink); line-height: 1.3; }
.fyf-row__then { display: flex; align-items: center; gap: clamp(0.8rem, 1.5vw, 1.2rem); border-left: 1px solid rgba(11, 19, 43, 0.12); padding-left: clamp(1.2rem, 2.5vw, 2rem); }
.fyf-row__chip { width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; flex: 0 0 auto; transition: background .3s ease, color .3s ease; }
.fyf-row:hover .fyf-row__chip { background: var(--mint); color: #fff; }
.fyf-row__meta { display: flex; flex-direction: column; }
.fyf-row__meta .fyf-row__lbl { margin-bottom: 0.15rem; }
.fyf-row__name { font-family: var(--font-display); font-weight: 600; font-size: clamp(0.95rem, 1.4vw, 1.15rem); color: var(--light-ink); white-space: nowrap; }
.fyf-row__arrow { color: var(--light-muted); transition: transform .3s ease, color .3s ease; flex: 0 0 auto; }
.fyf-row:hover .fyf-row__arrow { color: var(--mint-dim); transform: translate(2px, -2px); }
@media (max-width: 760px) {
	.fyf-row { grid-template-columns: auto 1fr; }
	.fyf-row__then { grid-column: 1 / -1; border-left: none; border-top: 1px solid rgba(11, 19, 43, 0.1); padding-left: 0; padding-top: 1rem; margin-top: 0.4rem; }
}

/* Industries — results tabs */
.results__tabs { display: flex; flex-wrap: wrap; gap: 0.7rem; margin: clamp(2rem, 4vw, 3rem) 0 clamp(1.5rem, 3vw, 2.5rem); }
.results-tab { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); border: 1px solid var(--surface-line-strong); border-radius: 999px; padding: 0.6rem 1.2rem; transition: border-color .3s ease, color .3s ease, background .3s ease; }
.results-tab:hover { color: var(--text); }
.results-tab.is-active { border-color: var(--mint); color: var(--mint); background: var(--mint-soft); }
.results-panel { display: none; }
.results-panel.is-active { display: block; animation: fadepanel .5s cubic-bezier(.16,1,.3,1); }
.results__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.outcome-card { position: relative; overflow: hidden; border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); background: var(--ink-2); padding: clamp(1.6rem, 2.6vw, 2.2rem); min-height: 240px; display: flex; flex-direction: column; transition: border-color .35s ease, transform .35s ease; }
.outcome-card:hover { border-color: var(--mint); transform: translateY(-3px); }
.outcome-card::after { content: ""; position: absolute; top: -12%; right: -10%; width: 50%; height: 60%; border-radius: 50%; background: radial-gradient(circle, rgba(4, 229, 172, 0.16), transparent 65%); pointer-events: none; }
.outcome-card__label { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); margin-bottom: clamp(1.2rem, 2.5vw, 1.8rem); }
.outcome-card__metric { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(2.6rem, 5vw, 3.6rem); color: var(--mint); line-height: 1; margin-bottom: 1rem; }
.outcome-card p { position: relative; z-index: 1; color: var(--text-muted); font-size: 0.95rem; line-height: 1.55; }
.outcome-card__rule { position: relative; z-index: 1; margin-top: auto; padding-top: 1.4rem; width: 34px; height: 2px; }
.outcome-card__rule::after { content: ""; display: block; width: 34px; height: 2px; border-radius: 2px; background: var(--surface-line-strong); }
@media (max-width: 860px) { .results__grid { grid-template-columns: 1fr; } }

/* Specialized AI — starting points */
.sp__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.sp-card { position: relative; overflow: hidden; display: flex; flex-direction: column; border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); background: var(--ink-2); padding: clamp(1.6rem, 2.6vw, 2.2rem); min-height: 380px; transition: border-color .35s ease, transform .35s ease; }
.sp-card:hover { border-color: var(--mint); transform: translateY(-3px); }
.sp-card__ghost { position: absolute; top: 0.5rem; right: 1rem; z-index: 0; line-height: 1; font-family: var(--font-display); font-size: clamp(4rem, 7vw, 6rem); color: transparent; -webkit-text-stroke: 1px var(--surface-line); pointer-events: none; }
.sp-card__label { position: relative; z-index: 1; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); }
.sp-card__title { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); line-height: 1.2; margin: 0.8rem 0 0.9rem; }
.sp-card__desc { position: relative; z-index: 1; color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; margin-bottom: 1.4rem; }
.sp-card__start { position: relative; z-index: 1; border: 1px solid var(--surface-line); border-radius: var(--radius-sm); padding: 1.1rem 1.2rem; background: rgba(4, 229, 172, 0.04); margin-bottom: 1.4rem; }
.sp-card__start-lbl { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); margin-bottom: 0.6rem; }
.sp-card__start p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.55; }
.sp-card__tags { position: relative; z-index: 1; display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.2rem; }
.sp-tag { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); border: 1px solid var(--surface-line-strong); border-radius: 999px; padding: 0.4rem 0.8rem; }
.sp-card__rule { position: relative; z-index: 1; margin-top: auto; width: 34px; height: 2px; border-radius: 2px; background: var(--surface-line-strong); transition: width .4s ease, background .4s ease; }
.sp-card:hover .sp-card__rule { width: 72px; background: var(--mint); }
@media (max-width: 880px) { .sp__grid { grid-template-columns: 1fr; max-width: 520px; margin-inline: auto; } }

/* Contact page — Let's Talk */
.ctc-hero { padding-block: clamp(7rem, 10vw, 9rem) clamp(2.5rem, 6vw, 4rem); }
.ctc-hero__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(2.5rem, 6vw, 5rem); align-items: start; }
.ctc-hero__kicker { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2.2rem, 5vw, 3.9rem); line-height: 1; margin: 0; }
.ctc-hero__headline { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.005em; font-size: clamp(1.4rem, 2.6vw, 2.05rem); line-height: 1.15; margin: 1.4rem 0 0; max-width: 16ch; }
.ctc-hero__lead { color: var(--text-muted); font-size: clamp(1rem, 1.4vw, 1.2rem); line-height: 1.65; margin: 1.6rem 0 2.4rem; max-width: 44ch; }
.ctc-hero__meta { display: grid; gap: 1.1rem; }
.ctc-meta__row { display: flex; align-items: center; gap: 0.9rem; color: var(--text); font-size: 0.95rem; }
.ctc-meta__chip { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; flex: 0 0 auto; border-radius: 50%; background: rgba(4, 229, 172, 0.12); color: var(--mint); }
a.ctc-meta__row:hover { color: var(--mint); }

.ctc-form__eyebrow { display: block; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 1.8rem; }
.ctc-form { display: grid; gap: 1.6rem; }
.ctc-field { display: grid; gap: 0.55rem; }
.ctc-field label { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.ctc-req { color: var(--mint); }
.ctc-field input, .ctc-field textarea { width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--surface-line); color: var(--text); font-family: var(--font-body); font-size: 0.98rem; padding: 0.55rem 0; transition: border-color .3s ease; }
.ctc-field textarea { resize: vertical; min-height: 90px; }
.ctc-field input::placeholder, .ctc-field textarea::placeholder { color: rgba(148, 163, 184, 0.55); }
.ctc-field input:focus, .ctc-field textarea:focus { outline: none; border-bottom-color: var(--mint); }
.ctc-form__btn { justify-self: stretch; margin-top: 0.6rem; background: #f8fafc; color: var(--ink); border: none; }
.ctc-form__btn:hover { background: #fff; transform: translateY(-2px); }
@media (max-width: 820px) { .ctc-hero__grid { grid-template-columns: 1fr; } }

/* Contact page — Global presence */
.gp__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.gp-card { border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 4px); background: #fff; padding: clamp(1.6rem, 3vw, 2.2rem); }
.gp-card--dark { background: var(--ink); border-color: var(--surface-line); }
.gp-card__top { display: flex; flex-direction: column; gap: 0.45rem; }
.gp-card__city { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.2vw, 1.6rem); line-height: 1.1; color: var(--light-ink); }
.gp-card--dark .gp-card__city { color: var(--text); }
.gp-card__country { color: var(--mint-dim); }
.gp-card--dark .gp-card__country { color: var(--mint); }
.gp-card__region { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint-dim); }
.gp-card--dark .gp-card__region { color: var(--mint); }
.gp-card__rule { display: block; height: 1px; background: rgba(11, 19, 43, 0.1); margin: 1.3rem 0; }
.gp-card--dark .gp-card__rule { background: var(--surface-line); }
.gp-card__rows { display: grid; gap: 0.9rem; }
.gp-row { display: flex; align-items: center; gap: 0.8rem; color: var(--light-muted); font-size: 0.95rem; }
.gp-card--dark .gp-row { color: var(--text-muted); }
.gp-row .icon { color: var(--mint-dim); flex: 0 0 auto; }
.gp-card--dark .gp-row .icon { color: var(--mint); }
.gp-row--strong { color: var(--light-ink); font-weight: 600; }
.gp-card--dark .gp-row--strong { color: var(--text); }
a.gp-row:hover { color: var(--mint-dim); }
.gp-card--dark a.gp-row:hover { color: var(--mint); }

.gp-map { position: relative; margin-top: 1.4rem; border-radius: calc(var(--radius) + 4px); overflow: hidden; border: 1px solid rgba(11, 19, 43, 0.12); }
.gp-map iframe { display: block; width: 100%; height: 460px; border: 0; }
.gp-map__pins { position: absolute; left: clamp(0.8rem, 2vw, 1.4rem); bottom: clamp(0.8rem, 2vw, 1.4rem); display: flex; flex-wrap: wrap; gap: 0.8rem; }
.gp-pin { display: flex; align-items: center; gap: 1.2rem; background: rgba(11, 19, 43, 0.94); border: 1px solid var(--surface-line); border-radius: var(--radius-sm); padding: 0.85rem 1.1rem; backdrop-filter: blur(8px); }
.gp-pin__meta { display: flex; flex-direction: column; gap: 0.1rem; }
.gp-pin__meta strong { font-family: var(--font-display); font-weight: 600; font-size: 0.95rem; color: var(--text); }
.gp-pin__meta span { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
.gp-pin__marker { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; background: rgba(4, 229, 172, 0.14); border: 1px solid rgba(4, 229, 172, 0.4); color: var(--mint); }
@media (max-width: 820px) { .gp__grid { grid-template-columns: 1fr; } .gp-map iframe { height: 360px; } .gp-map__pins { position: static; padding: 1rem; } }

/* Blog index */
.blogx__head { display: flex; flex-direction: column; gap: 1.6rem; margin-bottom: clamp(2rem, 4vw, 3rem); }
.blogx__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.1rem, 5vw, 3rem); line-height: 1; color: var(--light-ink); }
.blogx__filters { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.blogx-pill { padding: 0.5rem 1.15rem; border-radius: 999px; font-size: 0.88rem; color: var(--light-muted); transition: background .25s ease, color .25s ease; }
.blogx-pill:hover { color: var(--light-ink); }
.blogx-pill.is-active { background: var(--mint); color: var(--ink); font-weight: 600; }

.blogx-meta { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.1rem; }
.blogx-chip { font-size: 0.72rem; letter-spacing: 0.02em; color: var(--light-ink); background: #fff; border: 1px solid rgba(11, 19, 43, 0.12); border-radius: 999px; padding: 0.32rem 0.85rem; }
.blogx-date { font-size: 0.82rem; color: var(--light-muted); }

.blogx-feat { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.6rem, 4vw, 3rem); align-items: center; margin-bottom: clamp(2rem, 4vw, 3rem); }
.blogx-feat__media { display: block; position: relative; aspect-ratio: 4 / 3; border-radius: calc(var(--radius) + 4px); overflow: hidden; background: var(--ink); }
.blogx-feat__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.blogx-feat__media:hover img { transform: scale(1.04); }
.blogx-feat__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.5rem, 3vw, 2.1rem); line-height: 1.15; color: var(--light-ink); }
.blogx-feat__title a:hover { color: var(--mint-dim); }
.blogx-feat__excerpt { color: var(--light-muted); line-height: 1.65; margin: 1.1rem 0 1.6rem; max-width: 46ch; font-size: 0.95rem; }
.blogx-feat__more { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--mint-dim); font-weight: 600; }
.blogx-feat__more:hover { gap: 0.85rem; }

.blogx__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.blogx-card { position: relative; aspect-ratio: 16 / 11; border-radius: calc(var(--radius) + 4px); overflow: hidden; background: var(--ink); }
.blogx-card__media { display: block; position: absolute; inset: 0; }
.blogx-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.blogx-card:hover .blogx-card__media img { transform: scale(1.05); }
.blogx-chip--float { position: absolute; top: 1rem; left: 1rem; z-index: 2; }
.blogx-date--float { position: absolute; top: 1.1rem; right: 1.1rem; z-index: 2; color: #fff; text-shadow: 0 1px 8px rgba(11, 19, 43, 0.6); }
.blogx-card__overlay { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; display: flex; flex-direction: column; gap: 0.4rem; padding: 2.6rem 1.4rem 1.3rem; background: linear-gradient(to top, rgba(11, 19, 43, 0.92) 18%, rgba(11, 19, 43, 0.55) 55%, transparent); }
.blogx-card__title { font-family: var(--font-display); font-weight: 600; font-size: 1.12rem; line-height: 1.25; color: #fff; }
.blogx-card__excerpt { font-size: 0.86rem; line-height: 1.5; color: rgba(241, 245, 249, 0.78); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blogx-ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 600; font-size: 2.4rem; letter-spacing: 0.05em; color: rgba(4, 229, 172, 0.35); background: radial-gradient(circle at 30% 20%, rgba(4, 229, 172, 0.12), transparent 60%), var(--ink); }

.blogx-pager { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 0.5rem; margin-top: clamp(2.4rem, 5vw, 3.6rem); }
.blogx-pager .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px; padding: 0 0.5rem; border: 1px solid rgba(11, 19, 43, 0.15); border-radius: 11px; color: var(--light-ink); font-size: 0.92rem; transition: border-color .25s ease, background .25s ease, color .25s ease; }
.blogx-pager a.page-numbers:hover { border-color: var(--mint); color: var(--mint-dim); }
.blogx-pager .page-numbers.current { background: var(--ink); border-color: var(--ink); color: #fff; }
.blogx-pager .page-numbers.dots { border-color: transparent; }

.blogx__empty { text-align: center; padding: clamp(3rem, 8vw, 6rem) 0; }
.blogx__empty h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--light-ink); margin-bottom: 0.8rem; }
.blogx__empty p { color: var(--light-muted); max-width: 44ch; margin-inline: auto; }

/* Blog CTA */
.blogx-cta { position: relative; overflow: hidden; }
.blogx-cta__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.3rem); line-height: 1.1; color: var(--ink); }
.blogx-cta__sub { color: rgba(11, 19, 43, 0.78); max-width: 48ch; margin: 1.1rem auto 1.8rem; line-height: 1.6; }
.blogx-cta__actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 1rem; }
.blogx-cta__notes { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 1.6rem; list-style: none; margin: 2rem 0 0; padding: 0; }
.blogx-cta__notes li { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.95rem; color: rgba(11, 19, 43, 0.72); }
.blogx-cta__notes .icon { color: var(--ink); }

@media (max-width: 820px) {
	.blogx-feat { grid-template-columns: 1fr; }
	.blogx__grid { grid-template-columns: 1fr; }
}

/* All-in-One Solution — hero */
.aio-hero { position: relative; min-height: clamp(560px, 80vh, 780px); display: flex; align-items: center; overflow: hidden; padding-block: clamp(7rem, 12vh, 9rem) clamp(3rem, 6vw, 4.5rem); background: var(--ink); }
.aio-hero::before { content: ""; position: absolute; inset: 0; background-image: var(--aio-hero-img); background-size: cover; background-position: center; z-index: 0; }
.aio-hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(11, 19, 43, 0.35) 0%, rgba(11, 19, 43, 0.55) 45%, rgba(11, 19, 43, 0.96) 100%), linear-gradient(90deg, rgba(11, 19, 43, 0.7) 0%, rgba(11, 19, 43, 0.15) 55%, rgba(11, 19, 43, 0.3) 100%); }
.aio-hero .container-x { position: relative; z-index: 2; width: 100%; }
.aio-hero__grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.aio-hero__inner { max-width: 60ch; }
.aio-hero__stats { width: 100%; }
.aio-hero__stats .aio-stats__list[data-reveal] { transform: translateX(48px); }
.aio-hero__stats .aio-stats__list[data-reveal].is-visible { transform: none; }
@media (max-width: 900px) { .aio-hero__grid { grid-template-columns: 1fr; gap: clamp(2rem, 6vw, 3rem); } }
.aio-hero__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.2rem, 5vw, 3.9rem); line-height: 1.06; color: var(--text); }
.aio-hero__title .serif-i { font-weight: 600; }
.aio-hero__sub { color: rgba(241, 245, 249, 0.85); font-size: clamp(1rem, 1.4vw, 1.2rem); line-height: 1.6; margin: 1.4rem 0 2rem; max-width: 62ch; }
.aio-hero__btn { text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.82rem; border-radius: 6px; padding: 0.95rem 1.6rem; }

/* All-in-One Solution — stats bars */
.aio-stats__list { display: grid; gap: clamp(1.6rem, 3.5vw, 2.6rem); }
.aio-bar { display: flex; align-items: center; justify-content: flex-end; gap: clamp(0.8rem, 1.5vw, 1.4rem); }
.aio-bar__track { flex: 0 1 var(--w); min-width: 0; height: clamp(34px, 4.4vw, 54px); border-radius: 3px; background: linear-gradient(270deg, rgba(7, 59, 51, 0.25) 0%, #07a981 58%, #04e5ac 100%); clip-path: polygon(22px 0, 100% 0, 100% 100%, 0 100%); transform: scaleX(0); transform-origin: right center; transition: transform 1.1s cubic-bezier(.2, .7, .2, 1); }
.aio-stats__list.is-visible .aio-bar__track { transform: scaleX(1); }
.aio-bar:nth-child(1) .aio-bar__track { transition-delay: 0.05s; }
.aio-bar:nth-child(2) .aio-bar__track { transition-delay: 0.18s; }
.aio-bar:nth-child(3) .aio-bar__track { transition-delay: 0.31s; }
.aio-bar:nth-child(4) .aio-bar__track { transition-delay: 0.44s; }
.aio-bar__val { flex: 0 0 auto; display: flex; flex-direction: column; gap: 0.1rem; text-align: right; }
.aio-bar__num { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1; color: var(--mint); }
.aio-bar__lbl { font-size: clamp(0.72rem, 1.2vw, 0.9rem); color: var(--text-muted); }
@media (max-width: 700px) { .aio-bar__track { flex-basis: calc(var(--w) * 0.85); } }

/* All-in-One — certifications strip */
.aio-certs { text-align: center; }
.aio-certs__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.4rem); color: var(--light-ink); }
.aio-certs__logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(1.5rem, 5vw, 3.5rem); margin-top: clamp(2rem, 4vw, 3rem); }
.aio-cert { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; letter-spacing: 0.02em; color: rgba(11, 19, 43, 0.3); transition: color .3s ease; }
.aio-cert:hover { color: rgba(11, 19, 43, 0.6); }

/* All-in-One — split header */
.aio-head { display: grid; grid-template-columns: 1.5fr 1fr; gap: 2rem clamp(2rem, 5vw, 4rem); align-items: end; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.aio-head__title { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.4rem); line-height: 1.05; margin-top: 1rem; }
.aio-head__intro { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; max-width: 38ch; padding-bottom: 0.4rem; }
@media (max-width: 820px) { .aio-head { grid-template-columns: 1fr; align-items: start; } }

/* All-in-One — feature card grid (dark) */
.aio-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.aio-fcard { position: relative; overflow: hidden; display: flex; flex-direction: column; background: linear-gradient(160deg, var(--ink-2), var(--ink)); border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); padding: clamp(1.6rem, 2.8vw, 2.3rem); min-height: 230px; transition: border-color .35s ease, box-shadow .35s ease, transform .35s ease; }
.aio-fcard::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 70% 25%, rgba(4, 229, 172, 0.13), transparent 60%); opacity: 0; transition: opacity .4s ease; pointer-events: none; }
.aio-fcard:hover { border-color: var(--mint); transform: translateY(-3px); box-shadow: var(--shadow-glow); }
.aio-fcard:hover::after { opacity: 1; }
.aio-fcard__ghost { position: absolute; top: 0.6rem; right: 1.2rem; z-index: 0; line-height: 1; font-family: var(--font-display); font-size: clamp(3.5rem, 6vw, 5rem); color: transparent; -webkit-text-stroke: 1px rgba(4, 229, 172, 0.07); pointer-events: none; }
.aio-fcard__chip { position: relative; z-index: 1; width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.12); color: var(--mint); display: grid; place-items: center; margin-bottom: clamp(1.4rem, 3vw, 2.2rem); }
.aio-fcard h3, .aio-fcard h3.serif { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--text); margin-bottom: 0.6rem; }
.aio-fcard p { position: relative; z-index: 1; color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; }
.aio-fcard__rule { position: relative; z-index: 1; margin-top: auto; padding-top: 1.4rem; }
.aio-fcard__rule::after { content: ""; display: block; width: 34px; height: 2px; border-radius: 2px; background: var(--surface-line-strong); transition: width .4s ease, background .4s ease; }
.aio-fcard:hover .aio-fcard__rule::after { width: 72px; background: var(--mint); }
@media (max-width: 860px) { .aio-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .aio-grid { grid-template-columns: 1fr; } }
.aio-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) { .aio-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .aio-grid--4 { grid-template-columns: 1fr; } }
.aio-place-cta { display: flex; justify-content: center; margin-top: clamp(2rem, 4vw, 3rem); }

/* All-in-One — light timeline variant */
.etl--light::before { background: linear-gradient(rgba(11, 19, 43, 0.18), rgba(11, 19, 43, 0.04)); }
.etl--light .etl-step__node { background: #fff; border-color: rgba(11, 19, 43, 0.15); color: var(--mint-dim); box-shadow: 0 0 0 5px rgba(4, 229, 172, 0.05); }
.etl--light .etl-step__card { background: #fff; border-color: rgba(11, 19, 43, 0.1); }
.etl--light .etl-step__card:hover { border-color: var(--mint); box-shadow: 0 30px 60px -45px rgba(4, 229, 172, 0.4); }
.etl--light .etl-step__card h3 { color: var(--light-ink); }
.etl--light .etl-step__card p { color: var(--light-muted); }

/* All-in-One — scenario cards (dark, brackets) */
.aio-scn__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.aio-scn { position: relative; overflow: hidden; display: flex; flex-direction: column; background: rgba(255, 255, 255, 0.015); border: 1px solid var(--surface-line); border-radius: var(--radius-sm); padding: clamp(1.6rem, 2.8vw, 2.2rem); min-height: 280px; transition: border-color .35s ease, transform .35s ease; }
.aio-scn:hover { border-color: var(--mint); transform: translateY(-3px); }
.aio-scn::before, .aio-scn::after { content: ""; position: absolute; width: 16px; height: 16px; border-color: var(--mint); pointer-events: none; }
.aio-scn::before { top: 12px; left: 12px; border-top: 1.5px solid; border-left: 1.5px solid; }
.aio-scn::after { bottom: 12px; right: 12px; border-bottom: 1.5px solid; border-right: 1.5px solid; }
.aio-scn__ghost { position: absolute; top: 0.6rem; right: 1.2rem; z-index: 0; line-height: 1; font-family: var(--font-display); font-size: clamp(3.5rem, 6vw, 5rem); color: transparent; -webkit-text-stroke: 1px rgba(4, 229, 172, 0.07); pointer-events: none; }
.aio-scn__label { position: relative; z-index: 1; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint); }
.aio-scn__title { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); line-height: 1.2; color: var(--text); margin: 0.9rem 0 0.8rem; }
.aio-scn__desc { position: relative; z-index: 1; color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; margin-bottom: 1.6rem; }
.aio-scn__tag { position: relative; z-index: 1; margin-top: auto; align-self: flex-start; display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mint); border: 1px solid var(--surface-line-strong); border-radius: 999px; padding: 0.5rem 0.9rem; }
@media (max-width: 860px) { .aio-scn__grid { grid-template-columns: 1fr; max-width: 520px; margin-inline: auto; } }

/* All-in-One — comparison cards (light) */
.aio-vs__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.aio-vs { position: relative; overflow: hidden; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 4px); padding: clamp(1.8rem, 3vw, 2.6rem); }
.aio-vs--win { border-color: rgba(4, 229, 172, 0.4); box-shadow: 0 30px 70px -50px rgba(4, 229, 172, 0.45); }
.aio-vs--win::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 0% 0%, rgba(4, 229, 172, 0.1), transparent 55%); pointer-events: none; }
.aio-vs__top { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.2rem; }
.aio-vs__opt { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--light-muted); }
.aio-vs__badge { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light-muted); border: 1px solid rgba(11, 19, 43, 0.18); border-radius: 999px; padding: 0.35rem 0.8rem; }
.aio-vs__badge--rec { color: var(--mint-dim); border-color: rgba(4, 229, 172, 0.5); background: rgba(4, 229, 172, 0.08); }
.aio-vs__title { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.4rem, 2.6vw, 1.9rem); color: var(--light-ink); margin-bottom: 1.6rem; }
.aio-vs__list { position: relative; z-index: 1; display: grid; gap: 1rem; list-style: none; margin: 0; padding: 0; }
.aio-vs__list li { display: flex; align-items: flex-start; gap: 0.8rem; color: var(--light-ink); font-size: 0.95rem; line-height: 1.5; }
.aio-vs__ico { flex: 0 0 auto; display: inline-flex; margin-top: 0.05rem; }
.aio-vs__ico--yes { color: var(--mint-dim); }
.aio-vs__ico--no { color: #e5484d; }
@media (max-width: 820px) { .aio-vs__grid { grid-template-columns: 1fr; } }

/* All-in-One — FAQ accordion (light) */
.faq__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
.faq__intro { position: sticky; top: 7rem; }
.faq__intro h2 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: clamp(2rem, 4.5vw, 3.4rem); line-height: 1.05; color: var(--light-ink); margin: 1rem 0 1.2rem; }
.faq__intro p { color: var(--light-muted); font-size: 0.95rem; max-width: 34ch; line-height: 1.6; }
.faq-item { border-top: 1px solid rgba(11, 19, 43, 0.12); }
.faq-item:last-child { border-bottom: 1px solid rgba(11, 19, 43, 0.12); }
.faq-item__head { display: flex; align-items: center; gap: 1.2rem; width: 100%; padding: clamp(1.1rem, 2.2vw, 1.6rem) 0; cursor: pointer; text-align: left; background: none; }
.faq-item__num { flex: 0 0 auto; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; color: var(--light-muted); }
.faq-item__q { flex: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.1rem, 1.8vw, 1.4rem); color: var(--light-ink); transition: color .3s ease; }
.faq-item__head:hover .faq-item__q { color: var(--mint-dim); }
.faq-item__icon { position: relative; flex: 0 0 auto; width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(11, 19, 43, 0.18); transition: background .3s ease, border-color .3s ease; }
.faq-item__icon::before, .faq-item__icon::after { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--light-ink); transition: opacity .3s ease, background .3s ease; }
.faq-item__icon::before { width: 12px; height: 1.6px; }
.faq-item__icon::after { width: 1.6px; height: 12px; }
.faq-item.is-open .faq-item__icon { background: rgba(4, 229, 172, 0.18); border-color: var(--mint); }
.faq-item.is-open .faq-item__icon::before, .faq-item.is-open .faq-item__icon::after { background: var(--mint-dim); }
.faq-item.is-open .faq-item__icon::after { opacity: 0; }
.faq-item__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .45s cubic-bezier(.16, 1, .3, 1); }
.faq-item.is-open .faq-item__body { grid-template-rows: 1fr; }
.faq-item__inner { overflow: hidden; min-height: 0; }
.faq-item__inner p { color: var(--light-muted); font-size: 0.95rem; line-height: 1.7; padding: 0 0 1.5rem; padding-left: 2.5rem; max-width: 62ch; }
@media (max-width: 860px) { .faq__grid { grid-template-columns: 1fr; } .faq__intro { position: static; } .faq-item__inner p { padding-left: 0; } }

/* Level Up — standards switcher (light) */
.std__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(1.5rem, 3vw, 2.5rem); align-items: start; }
.std__list { display: grid; gap: 0.8rem; }
.std-row { display: flex; align-items: center; gap: 1rem; width: 100%; text-align: left; background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: var(--radius-sm); padding: 0.9rem 1.2rem; cursor: pointer; transition: border-color .3s ease, background .3s ease, box-shadow .3s ease; }
.std-row:hover { border-color: rgba(4, 229, 172, 0.4); }
.std-row.is-active { background: rgba(4, 229, 172, 0.06); border-color: var(--mint); box-shadow: 0 14px 30px -22px rgba(4, 229, 172, 0.5); }
.std-row__chip { flex: 0 0 auto; width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; background: rgba(11, 19, 43, 0.04); color: var(--light-muted); border: 1px solid rgba(11, 19, 43, 0.08); transition: background .3s ease, color .3s ease, border-color .3s ease; }
.std-row.is-active .std-row__chip { background: rgba(4, 229, 172, 0.16); color: var(--mint-dim); border-color: rgba(4, 229, 172, 0.4); }
.std-row__name { flex: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem, 1.6vw, 1.2rem); color: var(--light-ink); }
.std-row__num { flex: 0 0 auto; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; color: var(--light-muted); }
.std__panels { position: relative; border: 1px solid rgba(11, 19, 43, 0.12); border-radius: calc(var(--radius) + 6px); background: #fff; padding: clamp(1.8rem, 3vw, 2.6rem); min-height: 340px; overflow: hidden; }
.std__panels::before, .std__panels::after { content: ""; position: absolute; width: 18px; height: 18px; border-color: rgba(11, 19, 43, 0.25); pointer-events: none; }
.std__panels::before { top: 14px; left: 14px; border-top: 1.5px solid; border-left: 1.5px solid; }
.std__panels::after { bottom: 14px; right: 14px; border-bottom: 1.5px solid; border-right: 1.5px solid; }
.std-panel { display: none; }
.std-panel.is-active { display: block; animation: stdFade .4s ease; }
@keyframes stdFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.std-panel__ghost { position: absolute; top: 0.2rem; right: 1rem; z-index: 0; line-height: 1; font-family: var(--font-display); font-size: clamp(5rem, 11vw, 9rem); color: transparent; -webkit-text-stroke: 1px rgba(11, 19, 43, 0.06); pointer-events: none; }
.std-panel__chip { position: relative; z-index: 1; width: 48px; height: 48px; border-radius: 12px; background: rgba(4, 229, 172, 0.14); color: var(--mint-dim); display: grid; place-items: center; margin-bottom: 1.4rem; }
.std-panel h3 { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.4rem, 2.4vw, 1.9rem); color: var(--light-ink); margin-bottom: 0.8rem; }
.std-panel p { position: relative; z-index: 1; color: var(--light-muted); font-size: 0.95rem; line-height: 1.65; max-width: 52ch; }
.std-panel__rule { position: relative; z-index: 1; display: block; width: 40px; height: 2px; background: var(--mint-dim); margin: 1.6rem 0 1rem; border-radius: 2px; }
.std-panel__foot { position: relative; z-index: 1; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint-dim); }
@media (max-width: 820px) { .std__grid { grid-template-columns: 1fr; } }

/* Careers — hero */
.careers-hero { padding-top: clamp(7rem, 12vw, 10rem); }
.careers-hero__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2.5rem, 5vw, 4.5rem); align-items: center; }
.careers-hero__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.2rem, 5vw, 3.9rem); line-height: 1.04; }
.careers-hero__sub { color: var(--text-muted); font-size: clamp(1rem, 1.5vw, 1.12rem); line-height: 1.6; margin: 1.6rem 0 2.2rem; max-width: 46ch; }
.careers-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.cstat-stack { display: grid; gap: 1rem; }
.cstat { display: flex; align-items: center; gap: 1.5rem; background: linear-gradient(160deg, var(--ink-2), var(--ink)); border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 2px); padding: clamp(1.1rem, 2vw, 1.5rem) clamp(1.4rem, 2.5vw, 2rem); transition: border-color .3s ease, transform .3s ease; }
.cstat:hover { border-color: var(--mint); transform: translateX(4px); }
.cstat__num { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--mint); min-width: 4.5rem; }
.cstat__lbl { color: var(--text-muted); font-size: 0.95rem; }
@media (max-width: 860px) { .careers-hero__grid { grid-template-columns: 1fr; } }

/* Careers — amenities */
.amen { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); }
.amen-cell { position: relative; padding: clamp(1.6rem, 2.6vw, 2.2rem); }
.amen-cell + .amen-cell::before { content: ""; position: absolute; left: 0; top: 1.2rem; bottom: 1.2rem; width: 1px; background: var(--surface-line); }
.amen-cell__chip { width: 44px; height: 44px; border-radius: 12px; background: rgba(4, 229, 172, 0.12); color: var(--mint); display: grid; place-items: center; margin-bottom: 1.3rem; }
.amen-cell h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem); color: var(--text); margin-bottom: 0.5rem; }
.amen-cell p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; }
@media (max-width: 900px) { .amen { grid-template-columns: 1fr 1fr; } .amen-cell + .amen-cell::before { display: none; } .amen-cell { border-top: 1px solid var(--surface-line); } .amen-cell:nth-child(1), .amen-cell:nth-child(2) { border-top: none; } }
@media (max-width: 520px) { .amen { grid-template-columns: 1fr; } .amen-cell:nth-child(2) { border-top: 1px solid var(--surface-line); } }

/* Careers — open roles */
.jobs__header { display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: end; margin-bottom: clamp(1.5rem, 3vw, 2.2rem); }
.jobs__search { display: flex; align-items: center; gap: 0.6rem; background: var(--ink-2); border: 1px solid var(--surface-line); border-radius: 999px; padding: 0.8rem 1.2rem; min-width: 300px; }
.jobs__search .icon { color: var(--text-muted); flex: 0 0 auto; }
.jobs__search input { background: transparent; border: none; outline: none; color: var(--text); font-family: var(--font-body); font-size: 0.95rem; width: 100%; }
.jobs__search input::placeholder { color: var(--text-faint); }
.jobs__filters { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 1.4rem; }
.jobs-pill { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); border: 1px solid var(--surface-line-strong); border-radius: 999px; padding: 0.55rem 1.1rem; cursor: pointer; background: transparent; transition: border-color .25s ease, color .25s ease, background .25s ease; }
.jobs-pill:hover { border-color: var(--mint); color: var(--mint); }
.jobs-pill.is-active { background: rgba(4, 229, 172, 0.12); border-color: var(--mint); color: var(--mint); }
.jobs__table { border: 1px solid var(--surface-line); border-radius: calc(var(--radius) + 4px); overflow: hidden; }
.jobs__thead { display: grid; grid-template-columns: 2.2fr 1fr 1fr 1.4fr auto; gap: 1rem; padding: 1rem clamp(1.2rem, 2.5vw, 2rem); border-bottom: 1px solid var(--surface-line); }
.jobs__thead span { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint); }
.jobs__thead span:last-child { text-align: right; }
.jobs-row { display: grid; grid-template-columns: 2.2fr 1fr 1fr 1.4fr auto; gap: 1rem; align-items: center; padding: clamp(1.1rem, 2vw, 1.5rem) clamp(1.2rem, 2.5vw, 2rem); border-bottom: 1px solid var(--surface-line); transition: background .25s ease; }
.jobs-row:last-child { border-bottom: none; }
.jobs-row:hover { background: rgba(255, 255, 255, 0.015); }
.jobs-row__role { display: flex; align-items: center; gap: 1rem; }
.jobs-row__chip { flex: 0 0 auto; width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--surface-line-strong); color: var(--mint); display: grid; place-items: center; }
.jobs-row__name { font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem, 1.6vw, 1.2rem); color: var(--text); }
.jobs-row__type, .jobs-row__loc { display: flex; align-items: center; gap: 0.5rem; color: var(--text-muted); font-size: 0.9rem; }
.jobs-row__type .icon, .jobs-row__loc .icon { color: var(--mint); flex: 0 0 auto; }
.jobs-row__dept { color: var(--text-muted); font-size: 0.9rem; }
.jobs-row__action { justify-self: end; }
.jobs-apply { display: inline-flex; align-items: center; gap: 0.4rem; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text); border: 1px solid var(--surface-line-strong); border-radius: 999px; padding: 0.5rem 0.9rem; transition: border-color .25s ease, color .25s ease; }
.jobs-apply:hover { border-color: var(--mint); color: var(--mint); }
.jobs__empty { padding: 2.5rem; text-align: center; color: var(--text-muted); }
@media (max-width: 860px) {
	.jobs__header { grid-template-columns: 1fr; align-items: start; }
	.jobs__search { min-width: 0; }
	.jobs__thead { display: none; }
	.jobs-row { grid-template-columns: 1fr auto; row-gap: 0.6rem; }
	.jobs-row__role { grid-column: 1; grid-row: 1; }
	.jobs-row__action { grid-column: 2; grid-row: 1; }
	.jobs-row__type { grid-column: 1 / -1; grid-row: 2; }
	.jobs-row__dept { grid-column: 1 / -1; grid-row: 3; }
	.jobs-row__loc { grid-column: 1 / -1; grid-row: 4; }
}

/* Job detail (single Open Role) */
.job-detail__wrap { max-width: 880px; margin-inline: auto; }
.job-detail__back { display: inline-flex; align-items: center; gap: 0.4rem; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--mint-dim); margin-bottom: 1.4rem; }
.job-detail__back:hover { color: var(--mint); }
.job-detail__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.8rem, 4vw, 2.8rem); line-height: 1.1; color: var(--light-ink); }
.job-detail__intro { color: var(--light-muted); font-size: 0.95rem; line-height: 1.6; margin: 1rem 0 1.2rem; max-width: 60ch; }
.job-detail__meta { display: flex; flex-wrap: wrap; gap: 1.4rem; margin-bottom: 1.8rem; }
.job-detail__meta span { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--light-muted); font-size: 0.9rem; }
.job-detail__meta .icon { color: var(--mint-dim); }
.job-detail__cta { margin-bottom: 0.5rem; }
.job-detail__rule { height: 2px; background: linear-gradient(90deg, var(--mint), rgba(4, 229, 172, 0.1)); border-radius: 2px; margin: 2.4rem 0; }
.job-block { margin-bottom: 2.4rem; }
.job-block h2 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 2.4vw, 1.7rem); color: var(--light-ink); margin-bottom: 1.1rem; }
.job-block p { color: var(--light-muted); line-height: 1.7; margin-bottom: 1rem; max-width: 68ch; font-size: 0.95rem; }
.job-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.7rem; }
.job-list--cols { grid-template-columns: 1fr 1fr; gap: 0.7rem 2rem; }
.job-list li { position: relative; padding-left: 1.7rem; color: var(--light-ink); font-size: 0.95rem; line-height: 1.5; }
.job-list li::before { content: ""; position: absolute; left: 0; top: 0.35em; width: 12px; height: 12px; border-radius: 3px; background: var(--mint); }
@media (max-width: 560px) { .job-list--cols { grid-template-columns: 1fr; } }

/* Application form */
.job-apply { max-width: 540px; margin-inline: auto; }
.job-form { display: grid; gap: 1rem; margin-top: 2rem; padding: clamp(1.6rem, 3vw, 2.4rem); background: #fff; border: 1px solid rgba(11, 19, 43, 0.1); border-radius: calc(var(--radius) + 4px); box-shadow: 0 30px 70px -50px rgba(11, 19, 43, 0.4); }
.job-form input[type="text"], .job-form input[type="email"] { width: 100%; background: #fff; border: 1px solid rgba(11, 19, 43, 0.18); border-radius: 10px; padding: 0.85rem 1rem; font-family: var(--font-body); font-size: 0.95rem; color: var(--light-ink); transition: border-color .25s ease; }
.job-form input::placeholder { color: rgba(71, 85, 105, 0.6); }
.job-form input:focus { outline: none; border-color: var(--mint); }
.job-form__file { display: inline-flex; align-items: center; gap: 0.8rem; cursor: pointer; }
.job-form__file-btn { display: inline-block; background: #eef2f6; border: 1px solid rgba(11, 19, 43, 0.18); border-radius: 8px; padding: 0.6rem 1rem; font-size: 0.88rem; color: var(--light-ink); white-space: nowrap; }
.job-form__file input[type="file"] { font-size: 0.85rem; color: var(--light-muted); max-width: 60%; }
.job-form__hint { color: var(--light-muted); font-size: 0.78rem; margin: 0; }
.job-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.job-form__submit { justify-self: stretch; text-align: center; justify-content: center; margin-top: 0.4rem; }
.job-form__notice { margin: 1.4rem 0 0; padding: 0.9rem 1.1rem; border-radius: 10px; font-size: 0.9rem; }
.job-form__notice.is-error { background: rgba(229, 72, 77, 0.1); border: 1px solid rgba(229, 72, 77, 0.4); color: #c23034; }

/* Thank you page */
.thankyou { min-height: 70vh; display: flex; align-items: center; }
.thankyou__inner { max-width: 620px; margin-inline: auto; text-align: center; }
.thankyou__icon { display: inline-grid; place-items: center; width: 84px; height: 84px; border-radius: 50%; background: rgba(4, 229, 172, 0.12); border: 1px solid rgba(4, 229, 172, 0.4); color: var(--mint); margin-bottom: 1.6rem; }
.thankyou__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.2rem, 5vw, 3.9rem); line-height: 1.04; margin: 1rem 0 1.2rem; }
.thankyou__sub { color: var(--text-muted); font-size: 0.95rem; line-height: 1.7; margin-bottom: 2.2rem; }
.thankyou__sub strong { color: var(--text); }
.thankyou__actions { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }

/* ---------- Mobile hero heights (auto, not full viewport) ---------- */
@media (max-width: 768px) {
	.about-hero, .comp-hero, .cons-hero, .aio-hero, .thankyou { min-height: auto; }
	.aio-hero { padding-block: clamp(7rem, 18vw, 8rem) clamp(2rem, 6vw, 3rem); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
	[data-reveal] { opacity: 1; transform: none; }
}
