/* ============================================================
   Zelescope — zls-chrome.css (v3 "Focus")
   Header / footer / hero signature + page blocks, light theme.
   ============================================================ */

/* ---------- HEADER ---------- */
.zls__header {
	position: sticky; top: 0; z-index: 50;
	background: rgba(247,247,243,.85); backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--zls-line);
	transition: box-shadow .2s ease, background .2s ease;
}
/* thin gradient accent pinned to the very top — the "scope" signal line */
.zls__header::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--zls-signal); }
.zls__header.is-stuck { box-shadow: 0 10px 30px -18px rgba(17,18,22,.35); background: rgba(247,247,243,.94); }
.zls__header-inner { display: flex; align-items: center; gap: 1rem; padding-block: 1rem; }
.zls__brand { display: flex; align-items: center; gap: .55rem; flex: none; }
.zls__brand img { height: 46px; width: auto; display: block; }
.zls__brand-fallback { font-family: var(--zls-display); font-weight: 800; font-size: var(--zls-step-2); letter-spacing: -.02em; }

/* status chip — pushes the nav cluster to the right and signals availability */
.zls__status { margin-left: auto; display: inline-flex; align-items: center; gap: .5rem;
	font-family: var(--zls-mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase;
	color: var(--zls-muted); background: #fff; border: 1px solid var(--zls-line);
	padding: .4rem .8rem; border-radius: 999px; }
.zls__status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--zls-lime); position: relative; }
.zls__status-dot::after { content: ""; position: absolute; inset: -4px; border-radius: 50%; border: 1px solid var(--zls-lime); opacity: .5; animation: zls-pulse 2.2s ease-out infinite; }
@keyframes zls-pulse { 0% { transform: scale(.6); opacity: .6; } 100% { transform: scale(1.6); opacity: 0; } }

.zls__nav { display: flex; align-items: center; gap: 1.7rem; font-family: var(--zls-mono); font-size: var(--zls-step--1); letter-spacing: .02em; text-transform: uppercase; }
.zls__nav > a:not(.zls__btn) { color: var(--zls-muted); transition: color .15s ease; position: relative; padding-block: .3rem; }
.zls__nav > a:not(.zls__btn)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -2px; height: 2px; background: var(--zls-signal); border-radius: 2px; transition: right .22s ease; }
.zls__nav > a:not(.zls__btn):hover { color: var(--zls-ink); }
.zls__nav > a:not(.zls__btn):hover::after { right: 0; }
.zls__nav-cta { margin-left: .3rem; }
.zls__cta-arrow { font-size: .9em; transition: transform .18s ease; display: inline-block; }
.zls__nav-cta:hover .zls__cta-arrow { transform: translate(2px,-2px); }
.zls__burger { display: none; background: #fff; border: 1px solid var(--zls-line); border-radius: 9px; width: 42px; height: 38px; cursor: pointer; color: var(--zls-ink); font-size: 1.15rem; }

@media (max-width: 1040px) { .zls__status { display: none; } .zls__nav { margin-left: auto; } }
@media (max-width: 900px) {
	.zls__nav { position: fixed; inset: 64px 0 auto 0; flex-direction: column; align-items: flex-start;
		gap: 0; background: #fff; border-bottom: 1px solid var(--zls-line);
		padding: .6rem var(--zls-gut) 1rem; transform: translateY(-130%); transition: transform .25s ease; box-shadow: 0 18px 30px -20px rgba(17,18,22,.25); margin-left: 0; }
	.zls__nav > a:not(.zls__btn) { padding: .8rem 0; width: 100%; border-bottom: 1px solid var(--zls-line); }
	.zls__nav > a:not(.zls__btn)::after { display: none; }
	.zls__nav.is-open { transform: translateY(0); }
	.zls__burger { display: block; margin-left: auto; }
	.zls__nav-cta { margin: .7rem 0 0; }
}

/* ---------- HERO ---------- */
.zls__hero { position: relative; overflow: hidden; padding-block: clamp(3rem, 2.2rem + 4vw, 5.5rem); }
.zls__hero-inner { display: grid; grid-template-columns: 1.08fr .92fr; gap: clamp(2rem,1rem + 3vw,4rem); align-items: center; position: relative; z-index: 2; }
.zls__hero h1 { font-size: var(--zls-step-4); font-weight: 800; margin: 1rem 0; letter-spacing: -.035em; }
.zls__hero p { font-size: var(--zls-step-1); color: var(--zls-muted); max-width: 46ch; }
.zls__hero-cta { display: flex; gap: .7rem; flex-wrap: wrap; margin-top: 1.6rem; }
.zls__hero-meta { display: flex; flex-wrap: nowrap; gap: clamp(1rem, .6rem + 1.2vw, 1.8rem); margin-top: 2.2rem; padding-top: 1.5rem; border-top: 1px solid var(--zls-line); }
.zls__hero-meta .zls__stat { position: relative; padding-right: clamp(1rem, .6rem + 1.2vw, 1.8rem); }
.zls__hero-meta .zls__stat b { font-size: var(--zls-step-1); }
.zls__hero-meta .zls__stat span { white-space: nowrap; }
.zls__hero-meta .zls__stat:not(:last-child)::after { content: ""; position: absolute; right: 0; top: .1rem; bottom: .1rem; width: 1px; background: var(--zls-line); }
.zls__hero-meta .zls__stat:last-child { padding-right: 0; }
@media (max-width: 620px){ .zls__hero-meta { flex-wrap: wrap; } }

/* viewfinder hero panel — signature */
.zls__view { position: relative; aspect-ratio: 1 / 1.04; max-width: 460px; width: 100%; margin-inline: auto;
	background: #fff; border: 1px solid var(--zls-line); border-radius: 18px; overflow: hidden;
	box-shadow: 0 30px 60px -34px rgba(17,18,22,.4); }
.zls__view-grid { position: absolute; inset: 0; background-image:
	linear-gradient(var(--zls-line) 1px, transparent 1px),
	linear-gradient(90deg, var(--zls-line) 1px, transparent 1px);
	background-size: 38px 38px; opacity: .6; }
.zls__view-reticle { position: absolute; inset: 0; }
.zls__view-reticle::before, .zls__view-reticle::after { content: ""; position: absolute; background: var(--zls-line); }
.zls__view-reticle::before { left: 8%; right: 8%; top: 50%; height: 1px; }
.zls__view-reticle::after { top: 8%; bottom: 8%; left: 50%; width: 1px; }
/* corner brackets */
.zls__view .br { position: absolute; width: 26px; height: 26px; }
.zls__view .br.tl { top: 14px; left: 14px; border-top: 2px solid var(--zls-lime); border-left: 2px solid var(--zls-lime); }
.zls__view .br.tr { top: 14px; right: 14px; border-top: 2px solid var(--zls-lime); border-right: 2px solid var(--zls-lime); }
.zls__view .br.bl { bottom: 14px; left: 14px; border-bottom: 2px solid var(--zls-lime); border-left: 2px solid var(--zls-lime); }
.zls__view .br.br2 { bottom: 14px; right: 14px; border-bottom: 2px solid var(--zls-lime); border-right: 2px solid var(--zls-lime); }
/* floating service tags acquired in the viewfinder */
.zls__view-tags { position: absolute; inset: 0; }
.zls__vt { position: absolute; font-family: var(--zls-mono); font-size: .68rem; letter-spacing: .02em;
	background: var(--zls-ink); color: #fff; padding: .3rem .6rem; border-radius: 7px; white-space: nowrap;
	box-shadow: 0 8px 18px -10px rgba(17,18,22,.6); opacity: 0; transform: translateY(6px);
	animation: zls-lock .6s ease forwards; }
.zls__vt::after { content: ""; position: absolute; width: 6px; height: 6px; border-radius: 50%; background: var(--zls-lime); right: -3px; top: -3px; box-shadow: 0 0 0 3px rgba(255,106,61,.25); }
.zls__vt.v1 { top: 20%; left: 16%; animation-delay: .25s; }
.zls__vt.v2 { top: 38%; right: 12%; animation-delay: .7s; }
.zls__vt.v3 { top: 57%; left: 12%; animation-delay: 1.15s; }
.zls__vt.v4 { top: 74%; right: 16%; animation-delay: 1.6s; }
@keyframes zls-lock { to { opacity: 1; transform: translateY(0); } }
.zls__view-center { position: absolute; inset: 0; display: grid; place-items: center; }
.zls__view-center span { width: 16px; height: 16px; border-radius: 50%; background: var(--zls-signal); box-shadow: 0 0 0 6px rgba(27,77,255,.12), 0 0 0 14px rgba(27,77,255,.06); }

@media (max-width: 900px) {
	.zls__hero-inner { grid-template-columns: 1fr; }
	.zls__view { max-width: 340px; order: -1; }
}

/* ---------- SECTION HEADINGS ---------- */
.zls__head { display: flex; flex-direction: column; gap: .8rem; margin-bottom: 2.4rem; max-width: 62ch; }
.zls__head h2 { font-size: var(--zls-step-3); letter-spacing: -.03em; }

/* ---------- PROCESS TIMELINE ---------- */
.zls__steps { display: grid; gap: 1px; background: var(--zls-line); border: 1px solid var(--zls-line); border-radius: var(--zls-radius); overflow: hidden; }
.zls__step { background: #fff; padding: 1.6rem; display: grid; gap: .5rem; }
.zls__step .n { font-family: var(--zls-mono); color: var(--zls-cyan); font-size: var(--zls-step--1); letter-spacing: .08em; font-weight: 600; }
.zls__step h3 { font-size: var(--zls-step-1); }
.zls__step p { color: var(--zls-muted); margin: 0; }
@media (min-width: 760px){ .zls__steps { grid-template-columns: repeat(3,1fr); } }

/* ---------- CTA BAND (inverted dark block for contrast) ---------- */
.zls__band { background: var(--zls-ink-deep); color: #fff; border-radius: 20px; padding: clamp(3.4rem,2.6rem + 3vw,6rem) clamp(1.7rem,1rem + 3vw,3.6rem); text-align: center; position: relative; overflow: hidden; }
.zls__band::before { content: ""; position: absolute; inset: 0; pointer-events: none;
	background: radial-gradient(58% 80% at 50% -6%, rgba(27,77,255,.26), transparent 68%),
	            radial-gradient(46% 70% at 86% 112%, rgba(139,197,63,.16), transparent 70%); }
.zls__band .zls__grid-bg { background-image: radial-gradient(rgba(255,255,255,.1) 1.2px, transparent 1.2px); mask-image: none; -webkit-mask-image: none; opacity: .5; }
.zls__band-inner { position: relative; z-index: 2; max-width: 720px; margin-inline: auto; display: flex; flex-direction: column; align-items: center; gap: 1.1rem; }
.zls__band h2 { font-size: clamp(1.85rem, 1.3rem + 2.4vw, 3rem); letter-spacing: -.03em; max-width: 17ch; margin: 0; line-height: 1.06; }
.zls__band p { color: #aeb2bd; max-width: 46ch; margin: 0; }
.zls__badge { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--zls-mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: #c7cad3; border: 1px solid rgba(255,255,255,.16); border-radius: 999px; padding: .42rem .9rem; background: rgba(255,255,255,.04); }
.zls__badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--zls-lime); box-shadow: 0 0 0 3px rgba(139,197,63,.2); }
.zls__band .zls__btn--primary { background: #fff; color: var(--zls-ink); margin-top: .4rem; }
.zls__band .zls__btn--primary:hover { background: var(--zls-lime); color: var(--zls-ink); box-shadow: 0 14px 30px -14px rgba(139,197,63,.65); }
/* viewfinder brackets (green) framing the band — brand signature */
.zls__band > .br { position: absolute; width: 28px; height: 28px; z-index: 2; }
.zls__band > .br.tl { top: 24px; left: 24px; border-top: 2px solid var(--zls-lime); border-left: 2px solid var(--zls-lime); }
.zls__band > .br.tr { top: 24px; right: 24px; border-top: 2px solid var(--zls-lime); border-right: 2px solid var(--zls-lime); }
.zls__band > .br.bl { bottom: 24px; left: 24px; border-bottom: 2px solid var(--zls-lime); border-left: 2px solid var(--zls-lime); }
.zls__band > .br.br2 { bottom: 24px; right: 24px; border-bottom: 2px solid var(--zls-lime); border-right: 2px solid var(--zls-lime); }

/* ---------- FOOTER (dark, premium finish) ---------- */
.zls__footer { background: var(--zls-ink-deep); color: #c7cad3; margin-top: 2rem; position: relative; overflow: hidden; }
.zls__footer::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--zls-signal); z-index: 3; }
.zls__footer .zls__grid-bg { background-image: radial-gradient(rgba(255,255,255,.06) 1.2px, transparent 1.2px); background-size: 26px 26px; opacity: .6; -webkit-mask-image: linear-gradient(#000, transparent 70%); mask-image: linear-gradient(#000, transparent 70%); }

/* pre-footer CTA */
.zls__footer-cta { position: relative; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; padding-block: 3.4rem 2.8rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.zls__footer-cta .zls__eyebrow { color: #9cb6ff; }
.zls__footer-cta h2 { font-size: var(--zls-step-3); color: #fff; letter-spacing: -.03em; max-width: 20ch; margin-top: .7rem; }
.zls__footer .zls__btn--primary { background: #fff; color: var(--zls-ink); flex: none; }
.zls__footer .zls__btn--primary:hover { background: var(--zls-lime); color: var(--zls-ink); box-shadow: 0 14px 30px -14px rgba(139,197,63,.7); }

/* columns */
.zls__footer-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem 2.4rem; padding-block: 3rem 2rem; }
.zls__footer-brand .zls__brand { margin-bottom: 1.1rem; }
.zls__footer-brand .zls__brand img { height: 40px; filter: brightness(0) invert(1); opacity: .95; }
.zls__footer-tag { font-size: var(--zls-step--1); max-width: 34ch; color: #aeb2bd; margin: 0 0 1.1rem; line-height: 1.55; }
.zls__status--dark { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.13); color: #c7cad3; }
.zls__social { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.1rem; }
.zls__social a { font-family: var(--zls-mono); font-size: var(--zls-step--1); color: #aeb2bd; border: 1px solid rgba(255,255,255,.14); border-radius: 8px; padding: .4rem .75rem; transition: border-color .15s ease, color .15s ease; }
.zls__social a:hover { border-color: var(--zls-lime); color: #fff; }
.zls__footer h4 { font-family: var(--zls-mono); font-size: var(--zls-step--1); letter-spacing: .14em; text-transform: uppercase; color: #6c7080; margin-bottom: 1.1rem; }
.zls__footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .65rem; }
.zls__footer ul a { color: #aeb2bd; font-size: var(--zls-step--1); transition: color .15s ease, padding-left .15s ease; position: relative; }
.zls__footer ul a:hover { color: #fff; padding-left: 4px; }

/* oversized wordmark signature */
.zls__footer-mark { position: relative; z-index: 1; font-family: var(--zls-display); font-weight: 800; letter-spacing: -.04em; line-height: .8; text-align: center; white-space: nowrap; user-select: none; pointer-events: none; font-size: clamp(4rem, 17vw, 15rem); margin-top: 1rem; background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,0)); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* bottom bar */
.zls__footer-bottom { position: relative; z-index: 2; border-top: 1px solid rgba(255,255,255,.1); padding-block: 1.3rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-family: var(--zls-mono); font-size: var(--zls-step--1); color: #6c7080; }
.zls__footer-meta { flex: 1; text-align: center; min-width: 200px; }
.zls__totop { color: #aeb2bd; transition: color .15s ease; }
.zls__totop:hover { color: var(--zls-lime); }

@media (max-width: 760px){ .zls__footer-grid { grid-template-columns: 1fr 1fr; } .zls__footer-brand { grid-column: 1 / -1; } .zls__footer-meta { text-align: left; flex: none; } }
@media (max-width: 460px){ .zls__footer-grid { grid-template-columns: 1fr; } }

/* ---------- CAREERS / SCREENING ---------- */
.zls__apply { display: grid; grid-template-columns: 1.1fr .9fr; gap: 2rem; align-items: start; }
@media (max-width: 920px){ .zls__apply { grid-template-columns: 1fr; } }

.zls__photo-drop { border: 1px dashed var(--zls-line); border-radius: 12px; padding: 1rem; display: flex; align-items: center; gap: 1rem; background: var(--zls-void); }
.zls__photo-prev { width: 64px; height: 64px; border-radius: 10px; background: #fff; border: 1px solid var(--zls-line); object-fit: cover; display: grid; place-items: center; color: var(--zls-faint); font-family: var(--zls-mono); font-size: .6rem; flex: none; }

.zls__quiz { display: grid; gap: 1.2rem; }
.zls__q { background: var(--zls-void); border: 1px solid var(--zls-line); border-radius: 12px; padding: 1.1rem 1.2rem; }
.zls__q-head { display: flex; gap: .6rem; align-items: baseline; margin-bottom: .8rem; }
.zls__q-tag { font-family: var(--zls-mono); font-size: .66rem; letter-spacing: .06em; text-transform: uppercase; color: var(--zls-cyan); border: 1px solid var(--zls-line); border-radius: 999px; padding: .15rem .5rem; background: #fff; }
.zls__q p { margin: 0; font-weight: 600; }
.zls__opts { display: grid; gap: .5rem; margin-top: .8rem; }
.zls__opt { display: flex; gap: .6rem; align-items: center; padding: .6rem .8rem; border: 1px solid var(--zls-line); border-radius: 9px; cursor: pointer; background: #fff; transition: border-color .12s ease, background .12s ease; }
.zls__opt:hover { border-color: var(--zls-cyan); }
.zls__opt input { accent-color: var(--zls-cyan); width: 16px; height: 16px; }
.zls__opt.is-picked { border-color: var(--zls-cyan); background: rgba(27,77,255,.05); }

.zls__progress { height: 5px; background: var(--zls-line); border-radius: 999px; overflow: hidden; margin: 1rem 0 1.6rem; }
.zls__progress span { display: block; height: 100%; width: 0; background: var(--zls-signal); transition: width .3s ease; }

.zls__result { display: none; text-align: center; padding: 2rem 1rem; }
.zls__result.is-show { display: block; }
.zls__result .ring { width: 124px; height: 124px; margin: 0 auto 1rem; border-radius: 50%; display: grid; place-items: center; background: conic-gradient(var(--zls-cyan) var(--deg,0deg), var(--zls-line) 0deg); }
.zls__result .ring b { width: 98px; height: 98px; border-radius: 50%; background: #fff; display: grid; place-items: center; font-family: var(--zls-display); font-size: var(--zls-step-2); font-weight: 800; }
.zls__chip { display: inline-flex; gap: .4rem; align-items: center; font-family: var(--zls-mono); font-size: var(--zls-step--1); padding: .3rem .7rem; border-radius: 999px; border: 1px solid var(--zls-line); margin: .2rem; background: #fff; }
.zls__chip.good { color: var(--zls-good); border-color: rgba(17,158,106,.35); }
.zls__chip.warn { color: var(--zls-amber); border-color: rgba(201,137,43,.4); }

.zls__roles { display: grid; gap: .8rem; }
.zls__role { display: flex; justify-content: space-between; gap: 1rem; padding: 1rem 1.2rem; border: 1px solid var(--zls-line); border-radius: 12px; background: #fff; transition: border-color .15s ease; }
.zls__role:hover { border-color: var(--zls-ink); }
.zls__role .t { font-family: var(--zls-display); font-weight: 700; }
.zls__role .m { font-family: var(--zls-mono); font-size: var(--zls-step--1); color: var(--zls-muted); }

.zls__note { font-family: var(--zls-mono); font-size: var(--zls-step--1); color: var(--zls-faint); margin-top: 1rem; }

.zls__alert { border-radius: 10px; padding: .8rem 1rem; font-size: var(--zls-step--1); margin-top: 1rem; display: none; }
.zls__alert.is-show { display: block; }
.zls__alert.ok { border: 1px solid rgba(17,158,106,.4); color: var(--zls-good); background: rgba(17,158,106,.06); }
.zls__alert.err { border: 1px solid rgba(214,69,69,.4); color: #c33; background: rgba(214,69,69,.06); }

/* ---------- ABOUT values ---------- */
.zls__values { display: grid; gap: 1px; background: var(--zls-line); border: 1px solid var(--zls-line); border-radius: var(--zls-radius); overflow: hidden; }
@media (min-width:760px){ .zls__values { grid-template-columns: repeat(2,1fr); } }
.zls__value { background: #fff; padding: 1.6rem; }
.zls__value h3 { font-size: var(--zls-step-1); margin-bottom: .4rem; }
.zls__value p { color: var(--zls-muted); margin: 0; }

/* ---------- BLOG ---------- */
.zls__posts { display: grid; gap: 1.4rem; }
@media (min-width:760px){ .zls__posts { grid-template-columns: repeat(3,1fr); } }
.zls__post { display: flex; flex-direction: column; gap: .6rem; }
.zls__post .cat { font-family: var(--zls-mono); font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; color: var(--zls-cyan); }
.zls__post h3 { font-size: var(--zls-step-1); }
.zls__post p { color: var(--zls-muted); margin: 0; font-size: var(--zls-step--1); }
.zls__post .more { font-family: var(--zls-mono); font-size: var(--zls-step--1); color: var(--zls-cyan); margin-top: auto; }

/* ---------- BUTTON TEXT COLORS (authoritative) ----------
   Placed last and element-qualified so they outrank `.zls a {color:inherit}`,
   `.zls__nav a {color}`, AND a host theme's `.entry-content button {}` rules
   (specificity 0,1,1) that would otherwise override our background/border and
   leave white-on-white (invisible-until-hover) buttons. We pin background,
   color AND border together so no single theme rule can break them. */
.zls a.zls__btn, .zls button.zls__btn { border: 1px solid transparent; text-decoration: none; }
.zls a.zls__btn.zls__btn--primary, .zls button.zls__btn.zls__btn--primary { background: var(--zls-ink); color: #fff; border-color: var(--zls-ink); }
.zls a.zls__btn.zls__btn--primary:hover, .zls button.zls__btn.zls__btn--primary:hover { background: var(--zls-cyan); color: #fff; border-color: var(--zls-cyan); }
.zls a.zls__btn.zls__btn--ghost, .zls button.zls__btn.zls__btn--ghost { background: #fff; color: var(--zls-ink); border-color: var(--zls-line); }
.zls a.zls__btn.zls__btn--ghost:hover, .zls button.zls__btn.zls__btn--ghost:hover { border-color: var(--zls-ink); }
/* contextual overrides (dark band / footer): white pill, no stray border. Placed
   after the generic rules and at equal specificity so they win on source order. */
.zls__band a.zls__btn.zls__btn--primary, .zls__band button.zls__btn.zls__btn--primary { background: #fff; color: var(--zls-ink); border-color: #fff; }
.zls__band a.zls__btn.zls__btn--primary:hover, .zls__band button.zls__btn.zls__btn--primary:hover { background: var(--zls-lime); color: var(--zls-ink); border-color: var(--zls-lime); }
.zls__footer a.zls__btn.zls__btn--primary, .zls__footer button.zls__btn.zls__btn--primary { background: #fff; color: var(--zls-ink); border-color: #fff; }
.zls__footer a.zls__btn.zls__btn--primary:hover, .zls__footer button.zls__btn.zls__btn--primary:hover { background: var(--zls-lime); color: var(--zls-ink); border-color: var(--zls-lime); }

/* ============================================================
   SERVICE PAGES — shared components (hero, before/after, caps, faq)
   Reused across AI Agents, E-commerce, and future service pages.
   ============================================================ */
.zls__svc-hero { position: relative; overflow: hidden; padding-block: clamp(3rem,2rem + 4vw,5.5rem); }
.zls__svc-hero-inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,1rem + 3vw,4rem); align-items: center; position: relative; z-index: 2; }
.zls__svc-hero h1 { font-size: var(--zls-step-4); font-weight: 800; letter-spacing: -.035em; margin: 1rem 0; }
.zls__svc-hero p.lede { font-size: var(--zls-step-1); color: var(--zls-muted); max-width: 46ch; }
@media (max-width: 900px){ .zls__svc-hero-inner { grid-template-columns: 1fr; } .zls__svc-visual { order: -1; max-width: 340px; margin-inline: auto; } }

/* before / after */
.zls__ba { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
@media (max-width: 760px){ .zls__ba { grid-template-columns: 1fr; } }
.zls__ba-col { border: 1px solid var(--zls-line); border-radius: var(--zls-radius); padding: 1.6rem; background: #fff; }
.zls__ba-col.after { border-color: rgba(139,197,63,.5); box-shadow: 0 0 0 1px rgba(139,197,63,.25), 0 22px 40px -30px rgba(17,18,22,.3); }
.zls__ba-col h3 { font-size: var(--zls-step-1); margin-bottom: .2rem; }
.zls__ba-col .tag { font-family: var(--zls-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; color: var(--zls-faint); }
.zls__ba-col.after .tag { color: #5a8a1f; }
.zls__ba-col ul { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .6rem; }
.zls__ba-col li { color: var(--zls-muted); font-size: var(--zls-step--1); padding-left: 1.5rem; position: relative; }
.zls__ba-col li::before { position: absolute; left: 0; top: 0; }
.zls__ba-col.before li::before { content: "\00d7"; color: #c66; font-weight: 700; }
.zls__ba-col.after li::before { content: "\2713"; color: var(--zls-good); font-weight: 700; }

/* capability grid */
.zls__cap { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--zls-line); border: 1px solid var(--zls-line); border-radius: var(--zls-radius); overflow: hidden; }
@media (max-width: 760px){ .zls__cap { grid-template-columns: 1fr; } }
.zls__cap-item { background: #fff; padding: 1.5rem; display: grid; gap: .5rem; }
.zls__cap-item .k { display: inline-flex; width: 34px; height: 34px; border-radius: 9px; background: var(--zls-void); border: 1px solid var(--zls-line); align-items: center; justify-content: center; font-family: var(--zls-mono); color: var(--zls-cyan); font-size: .8rem; }
.zls__cap-item h3 { font-size: var(--zls-step-0); }
.zls__cap-item p { color: var(--zls-muted); font-size: var(--zls-step--1); margin: 0; }

/* faq accordion */
.zls__faq { border: 1px solid var(--zls-line); border-radius: var(--zls-radius); overflow: hidden; background: #fff; }
.zls__faq details { border-bottom: 1px solid var(--zls-line); }
.zls__faq details:last-child { border-bottom: none; }
.zls__faq summary { cursor: pointer; list-style: none; padding: 1.2rem 1.4rem; font-family: var(--zls-display); font-weight: 600; font-size: var(--zls-step-0); display: flex; justify-content: space-between; gap: 1rem; align-items: center; }
.zls__faq summary::-webkit-details-marker { display: none; }
.zls__faq summary::after { content: "+"; color: var(--zls-cyan); font-family: var(--zls-mono); font-size: 1.2rem; transition: transform .2s ease; }
.zls__faq details[open] summary::after { transform: rotate(45deg); }
.zls__faq .a { padding: 0 1.4rem 1.3rem; color: var(--zls-muted); font-size: var(--zls-step--1); max-width: 70ch; }

/* ============================================================
   CAREERS — multi-step wizard
   ============================================================ */
.zls__wiz { position: relative; }
/* stepper */
.zls__stepper { display: flex; align-items: center; gap: .5rem; margin-bottom: 1.6rem; flex-wrap: wrap; }
.zls__stepper .s { display: flex; align-items: center; gap: .55rem; font-family: var(--zls-mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; color: var(--zls-faint); }
.zls__stepper .s .num { width: 24px; height: 24px; border-radius: 50%; border: 1px solid var(--zls-line); display: grid; place-items: center; font-size: .7rem; background: #fff; color: var(--zls-faint); transition: all .2s ease; flex: none; }
.zls__stepper .s.is-active .num { background: var(--zls-ink); color: #fff; border-color: var(--zls-ink); }
.zls__stepper .s.is-done .num { background: var(--zls-lime); color: var(--zls-ink); border-color: var(--zls-lime); }
.zls__stepper .s.is-active, .zls__stepper .s.is-done { color: var(--zls-ink); }
.zls__stepper .bar { flex: 1; min-width: 12px; height: 1px; background: var(--zls-line); }
@media (max-width: 720px){ .zls__stepper .s .lbl { display: none; } .zls__stepper .bar { min-width: 8px; } }

/* steps */
.zls__pane { display: none; animation: zls-pane-in .35s ease; }
.zls__pane.is-active { display: block; }
@keyframes zls-pane-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.zls__pane-h { margin-bottom: 1.2rem; }
.zls__pane-h h3 { font-size: var(--zls-step-2); letter-spacing: -.02em; }
.zls__pane-h p { color: var(--zls-muted); margin: .3rem 0 0; font-size: var(--zls-step--1); }

/* wizard nav */
.zls__wiz-nav { display: flex; justify-content: space-between; gap: 1rem; margin-top: 1.6rem; }
.zls__wiz-nav .spacer { flex: 1; }

/* skills timer */
.zls__timer { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--zls-mono); font-size: var(--zls-step--1); color: var(--zls-muted); border: 1px solid var(--zls-line); border-radius: 999px; padding: .35rem .8rem; background: #fff; }
.zls__timer .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--zls-lime); }
.zls__timer.is-low { color: #c33; border-color: rgba(214,69,69,.4); }
.zls__timer.is-low .dot { background: #d64545; animation: zls-blink .8s steps(2) infinite; }
@keyframes zls-blink { 50% { opacity: .25; } }

/* written round */
.zls__written { display: grid; gap: 1.2rem; }
.zls__wq { background: var(--zls-void); border: 1px solid var(--zls-line); border-radius: 12px; padding: 1.1rem 1.2rem; }
.zls__wq label { display: block; font-weight: 600; margin-bottom: .7rem; }
.zls__wq textarea { width: 100%; min-height: 120px; resize: vertical; border: 1px solid var(--zls-line); border-radius: 9px; padding: .8rem; font: inherit; font-size: var(--zls-step--1); background: #fff; color: var(--zls-ink); }
.zls__wq textarea:focus { outline: none; border-color: var(--zls-cyan); box-shadow: 0 0 0 3px rgba(27,77,255,.1); }
.zls__wq-foot { display: flex; justify-content: space-between; align-items: center; margin-top: .5rem; font-family: var(--zls-mono); font-size: .64rem; color: var(--zls-faint); }
.zls__wq-foot .count.ok { color: var(--zls-good); }

/* review */
.zls__review { display: grid; gap: .55rem; border: 1px solid var(--zls-line); border-radius: 12px; padding: 1.2rem; background: var(--zls-void); }
.zls__review .r { display: flex; justify-content: space-between; gap: 1rem; font-size: var(--zls-step--1); padding: .35rem 0; border-bottom: 1px dashed var(--zls-line); }
.zls__review .r:last-child { border-bottom: none; }
.zls__review .r .k { color: var(--zls-faint); font-family: var(--zls-mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .04em; }
.zls__review .r .v { font-weight: 600; text-align: right; }
.zls__consent { display: flex; gap: .6rem; align-items: flex-start; margin-top: 1.1rem; font-size: var(--zls-step--1); color: var(--zls-muted); }
.zls__consent input { margin-top: .2rem; accent-color: var(--zls-cyan); width: 16px; height: 16px; flex: none; }

/* honeypot — visually hidden, off-screen, not display:none (so bots fill it) */
.zls__hp { position: absolute; left: -9999px; top: -9999px; width: 1px; height: 1px; overflow: hidden; opacity: 0; }

/* clickable service cards (homepage grid → detail pages) */
.zls__card--link { display: block; text-decoration: none; transition: transform .18s ease, border-color .18s ease, box-shadow .2s ease; }
.zls__card--link:hover { transform: translateY(-3px); border-color: var(--zls-ink); box-shadow: 0 24px 44px -30px rgba(17,18,22,.4); }
.zls__card-go { display: inline-flex; align-items: center; gap: .4rem; margin-top: 1rem; font-family: var(--zls-mono); font-size: var(--zls-step--1); text-transform: uppercase; letter-spacing: .04em; color: var(--zls-cyan); }
.zls__card-go .arr { transition: transform .18s ease; }
.zls__card--link:hover .zls__card-go .arr { transform: translateX(4px); }
