/* ============================================================
   Chronon 2026 — main stylesheet
   Dark, premium, motion-led. No framework.
   ============================================================ */

:root {
	--bg:        #0a0a0f;
	--bg-2:      #111119;
	--surface:   #15151f;
	--line:      rgba(255,255,255,.10);
	--ink:       #f4f4f0;
	--ink-soft:  #a7a7b4;
	--ink-dim:   #6b6b78;
	--brand:     #17b4c8;   /* Chronon turquoise — logo emblem */
	--brand-2:   #45e0e4;   /* bright cyan accent */
	--brand-3:   #0c6f86;   /* deep teal */
	--grad:      linear-gradient(120deg, var(--brand-3) 0%, var(--brand) 50%, var(--brand-2) 100%);
	--maxw:      1320px;
	--gut:       clamp(20px, 5vw, 64px);
	--r:         16px;
	--ease:      cubic-bezier(.16,1,.3,1);
	--font-d:    "Space Grotesk", system-ui, sans-serif;
	--font-b:    "Inter", system-ui, -apple-system, sans-serif;
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-stopped { overflow: hidden; }

body {
	font-family: var(--font-b);
	background: var(--bg);
	color: var(--ink);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
img, svg, iframe { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
ul { list-style: none; padding: 0; }

::selection { background: var(--brand); color: #fff; }

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

.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.skip-link { position: fixed; top: -100px; left: 16px; z-index: 9999; background: var(--brand); color: #fff; padding: 10px 16px; border-radius: 8px; }
.skip-link:focus { top: 16px; }

/* ---------- type ---------- */
h1, h2, h3, h4 { font-family: var(--font-d); font-weight: 600; line-height: 1.04; letter-spacing: -0.02em; }
.eyebrow {
	font-family: var(--font-d);
	font-size: .8rem; font-weight: 500; letter-spacing: .22em; text-transform: uppercase;
	color: var(--brand-2); display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--brand-2); display: inline-block; }

.display { font-size: clamp(2.6rem, 8vw, 7.5rem); line-height: .98; }
.h2 { font-size: clamp(2rem, 5vw, 4rem); }
.h3 { font-size: clamp(1.4rem, 2.6vw, 2.2rem); }
.lead { font-size: clamp(1.05rem, 1.6vw, 1.4rem); color: var(--ink-soft); max-width: 56ch; }
.text-grad { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ---------- buttons ---------- */
.btn {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--font-d); font-weight: 500; font-size: .95rem;
	padding: 14px 26px; border-radius: 100px; position: relative;
	transition: transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease);
	will-change: transform;
}
.btn:hover { transform: translateY(-2px); }
.btn--solid { background: var(--ink); color: #0a0a0f; }
.btn--solid:hover { background: #fff; }
.btn--ghost { border: 1px solid var(--line); color: var(--ink); }
.btn--ghost:hover { border-color: var(--ink); background: rgba(255,255,255,.04); }
.btn--grad { background: var(--grad); color: #fff; background-size: 200% 200%; animation: gradshift 6s ease infinite; }
@keyframes gradshift { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }

/* ---------- loader ---------- */
.loader {
	position: fixed; inset: 0; z-index: 9000; background: var(--bg);
	display: grid; place-items: center;
}
.loader__word {
	font-family: var(--font-d); font-weight: 700; letter-spacing: .3em;
	font-size: clamp(1rem, 3vw, 1.6rem); color: var(--ink);
	overflow: hidden;
}
body.loaded .loader { pointer-events: none; }

/* ---------- header ---------- */
.site-header {
	position: fixed; top: 0; left: 0; right: 0; z-index: 800;
	padding: 46px 0 22px; transition: padding .4s var(--ease), background .4s var(--ease), backdrop-filter .4s var(--ease);
}
.site-header.is-stuck {
	padding: 22px 0 14px; background: rgba(10,10,15,.72); backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--line);
}
.site-header.is-hidden { transform: translateY(-100%); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; }

.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand__logo { height: 30px; width: auto; display: block; }
.site-header.is-stuck .brand__logo { height: 26px; }
.site-footer .brand__logo { height: 34px; }

.nav-desktop { display: flex; align-items: center; gap: 36px; }
.nav-desktop__list { display: flex; gap: 30px; }
.nav-desktop__list a { font-family: var(--font-d); font-weight: 500; font-size: .98rem; color: var(--ink-soft); position: relative; padding: 6px 0; transition: color .3s; }
.nav-desktop__list a::after { content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 0; background: var(--brand-2); transition: width .35s var(--ease); }
.nav-desktop__list a:hover { color: var(--ink); }
.nav-desktop__list a:hover::after { width: 100%; }

.nav-toggle { display: none; width: 44px; height: 44px; flex-direction: column; gap: 6px; align-items: center; justify-content: center; }
.nav-toggle span { width: 24px; height: 2px; background: var(--ink); transition: transform .35s var(--ease), opacity .3s; }
.nav-toggle[aria-expanded="true"] span:first-child { transform: translateY(4px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:last-child { transform: translateY(-4px) rotate(-45deg); }

.nav-overlay {
	position: fixed; inset: 0; z-index: 700; background: var(--bg-2);
	clip-path: circle(0% at calc(100% - 44px) 44px); transition: clip-path .7s var(--ease);
	display: grid; place-items: center; pointer-events: none;
}
.nav-overlay.is-open { clip-path: circle(150% at calc(100% - 44px) 44px); pointer-events: auto; }
.nav-overlay__list { text-align: center; }
.nav-overlay__list li { overflow: hidden; }
.nav-overlay__list a { font-family: var(--font-d); font-weight: 600; font-size: clamp(2rem, 9vw, 3.4rem); display: inline-flex; gap: 16px; align-items: baseline; padding: 8px 0; }
.nav-overlay__list a span { font-size: .9rem; color: var(--brand-2); }
.nav-overlay__mail { display: block; text-align: center; margin-top: 40px; color: var(--ink-soft); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; padding-bottom: clamp(40px, 8vh, 90px); overflow: hidden; }
.hero__canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 0; }
.hero::after { content: ""; position: absolute; inset: 0; z-index: 1; background: radial-gradient(120% 80% at 50% 100%, rgba(10,10,15,.85), transparent 60%), linear-gradient(180deg, rgba(10,10,15,.55), transparent 30%); pointer-events: none; }
.hero__inner { position: relative; z-index: 2; width: 100%; }
.hero__title { font-size: clamp(3rem, 11vw, 11rem); line-height: .9; font-weight: 700; }
.hero__title .line { display: block; overflow: hidden; }
.hero__title .line > span { display: block; }
.hero__row { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 32px; margin-top: 40px; }
.hero__sub { max-width: 40ch; }
.hero__scroll { display: inline-flex; align-items: center; gap: 12px; font-family: var(--font-d); font-size: .8rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-dim); }
.hero__scroll i { width: 1px; height: 40px; background: linear-gradient(var(--brand-2), transparent); display: inline-block; animation: scrolldrop 1.8s ease infinite; }
@keyframes scrolldrop { 0%{transform:scaleY(0);transform-origin:top} 40%{transform:scaleY(1);transform-origin:top} 60%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* marquee of capabilities — two identical groups, translate -50% loops seamlessly */
.marquee { border-block: 1px solid var(--line); padding: 22px 0; overflow: hidden; }
.marquee__track { display: flex; width: max-content; will-change: transform; }
.marquee__group { display: flex; flex: none; }
.marquee__group span { font-family: var(--font-d); font-size: clamp(1.2rem, 2.4vw, 2rem); color: var(--ink-dim); white-space: nowrap; display: inline-flex; align-items: center; padding-right: 48px; }
.marquee__group span::after { content: "✦"; color: var(--brand); margin-left: 48px; }

/* ============================================================
   SECTIONS
   ============================================================ */
.section { padding-block: clamp(80px, 14vh, 180px); position: relative; }
.section--tight { padding-block: clamp(60px, 9vh, 120px); }
.section__head { max-width: 60ch; margin-bottom: clamp(40px, 7vh, 90px); }
.section__head .h2 { margin-top: 18px; }

/* intro / what we do */
.intro__big { font-family: var(--font-d); font-weight: 500; font-size: clamp(1.6rem, 4vw, 3.2rem); line-height: 1.2; letter-spacing: -0.02em; max-width: 22ch; }
.intro__big em { font-style: normal; color: var(--ink-dim); }
.intro__big .text-grad { font-weight: 600; }

.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 32px; margin-top: 80px; border-top: 1px solid var(--line); padding-top: 50px; }
.stat__num { font-family: var(--font-d); font-weight: 600; font-size: clamp(2.4rem, 5vw, 4rem); line-height: 1; }
.stat__label { color: var(--ink-soft); margin-top: 8px; font-size: .95rem; }
.stat__placeholder { color: var(--ink-dim); -webkit-text-stroke: 1px var(--ink-dim); color: transparent; }

/* ---------- about ---------- */
.about__head { margin-bottom: clamp(30px, 5vh, 56px); }
.about__lead { margin-top: 18px; max-width: 18ch; }
.about__body { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(30px, 6vw, 80px); align-items: start; }
.about__body .prose .lead, .about__body .prose p { font-size: clamp(1.05rem, 1.5vw, 1.25rem); }
.about__body .prose em { font-style: normal; color: var(--ink); }
.about__meta { display: flex; flex-direction: column; gap: 0; }
.about__meta-item { padding: 16px 0; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 4px; font-family: var(--font-d); }
.about__meta-item span { color: var(--ink-dim); font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; }
.about__meta .service__link { margin-top: 22px; }
.about__meta--wide { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0 40px; }

/* ---------- under the hood ---------- */
.underhood { display: grid; grid-template-columns: 200px 1fr; gap: clamp(16px, 4vw, 48px); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: clamp(28px, 5vw, 48px) 0; }
.underhood__list { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px 32px; }
.underhood__list li { color: var(--ink); font-family: var(--font-d); font-size: clamp(1rem, 1.4vw, 1.15rem); padding-left: 26px; position: relative; }
.underhood__list li::before { content: ""; position: absolute; left: 0; top: .55em; width: 10px; height: 10px; border-radius: 3px; background: var(--grad); }
.underhood__list--rich { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px 32px; }
.underhood__list--rich li { padding-left: 0; display: flex; flex-direction: column; gap: 5px; border-top: 1px solid var(--line); padding-top: 16px; }
.underhood__list--rich li::before { display: none; }
.underhood__list--rich li strong { font-family: var(--font-d); font-weight: 600; color: var(--ink); font-size: clamp(1.05rem, 1.5vw, 1.2rem); }
.underhood__list--rich li span { color: var(--ink-soft); font-family: var(--font-b); font-size: .95rem; line-height: 1.5; }

/* ---------- services accordion/list ---------- */
.services { display: flex; flex-direction: column; border-top: 1px solid var(--line); }
.service {
	border-bottom: 1px solid var(--line); padding: clamp(28px, 5vw, 54px) 0; position: relative;
	display: grid; grid-template-columns: 90px 1fr; gap: clamp(16px,4vw,48px);
}
.service__num { font-family: var(--font-d); color: var(--brand-2); font-size: 1rem; padding-top: 10px; }
.service__title { font-size: clamp(1.8rem, 4.5vw, 3.4rem); transition: color .4s var(--ease); }
.service__lead { color: var(--ink-soft); margin-top: 14px; font-size: clamp(1.05rem,1.6vw,1.3rem); max-width: 50ch; }
.service__body { color: var(--ink-soft); margin-top: 20px; max-width: 62ch; }
.service__points { margin-top: 24px; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 10px 28px; }
.service__points li { color: var(--ink-soft); padding-left: 22px; position: relative; font-size: .98rem; }
.service__points li::before { content: ""; position: absolute; left: 0; top: .7em; width: 8px; height: 8px; border-radius: 50%; background: var(--grad); }
.service__link { display: inline-flex; align-items: center; gap: 10px; margin-top: 28px; font-family: var(--font-d); color: var(--ink); }
.service__link span { transition: transform .35s var(--ease); }
.service:hover .service__title { color: transparent; -webkit-text-stroke: 1px var(--ink); }
.service:hover .service__link span { transform: translateX(6px); }

/* ---------- portfolio wall ---------- */
.portfolio__filters { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 40px; }
.filter { padding: 8px 18px; border: 1px solid var(--line); border-radius: 100px; font-size: .9rem; color: var(--ink-soft); transition: all .3s; }
.filter.is-active, .filter:hover { background: var(--ink); color: #0a0a0f; border-color: var(--ink); }
.portfolio__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 22px; }
.work { grid-column: span 6; position: relative; border-radius: var(--r); overflow: hidden; background: var(--surface); border: 1px solid var(--line); }
.work:nth-child(4n+1), .work:nth-child(4n) { grid-column: span 6; }
.work__media { aspect-ratio: 16/10; overflow: hidden; position: relative; background: linear-gradient(135deg,#1a1a26,#0e0e16); }
.work__media img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .9s var(--ease), opacity .6s; transform: scale(1.04); }
.work:hover .work__media img { transform: scale(1.10); }
.work__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(10,10,15,.7)); }
.work__meta { position: absolute; left: 22px; right: 22px; bottom: 20px; z-index: 2; display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; }
.work__name { font-family: var(--font-d); font-weight: 600; font-size: 1.25rem; }
.work__tag { color: var(--brand-2); font-size: .82rem; letter-spacing: .04em; }
.work__arrow { width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; background: rgba(10,10,15,.5); flex: none; transition: background .3s, transform .3s; }
.work:hover .work__arrow { background: var(--ink); color: #0a0a0f; transform: rotate(-45deg); }
.work.is-hidden { display: none; }

/* ---------- process ---------- */
.process { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 0; border-top: 1px solid var(--line); }
.step { padding: 40px 30px 40px 0; border-bottom: 1px solid var(--line); }
.step__num { font-family: var(--font-d); font-size: 3rem; font-weight: 600; color: transparent; -webkit-text-stroke: 1px var(--brand); line-height: 1; }
.step__title { margin-top: 18px; font-size: 1.5rem; }
.step__body { color: var(--ink-soft); margin-top: 10px; }

/* ---------- logos / clients ---------- */
.clients { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 8px; }
.clients__cell { background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 30px 18px; display: grid; place-items: center; text-align: center; font-family: var(--font-d); font-weight: 600; font-size: 1.05rem; color: var(--ink-dim); transition: color .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease); }
.clients__cell:hover { color: var(--ink); background: var(--bg-2); border-color: rgba(255,255,255,.22); }
.clients__logo { max-height: 30px; max-width: 82%; width: auto; object-fit: contain; filter: brightness(0) invert(1); opacity: .66; transition: opacity .35s var(--ease); }
.clients__cell:hover .clients__logo { opacity: 1; }

/* ============================================================
   CTA / footer
   ============================================================ */
.site-footer { border-top: 1px solid var(--line); padding-block: clamp(60px,10vh,120px) 40px; background: linear-gradient(180deg, var(--bg), var(--bg-2)); }
.footer-cta { padding-bottom: clamp(50px,8vh,90px); border-bottom: 1px solid var(--line); margin-bottom: 60px; }
.footer-cta__eyebrow { color: var(--ink-dim); font-family: var(--font-d); letter-spacing: .1em; margin-bottom: 12px; }
.footer-cta__big { font-family: var(--font-d); font-weight: 700; font-size: clamp(2.4rem, 9vw, 8rem); line-height: .95; display: inline-flex; align-items: baseline; gap: .2em; flex-wrap: wrap; }
.footer-cta__big:hover { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.footer-cta__arrow { transition: transform .4s var(--ease); }
.footer-cta__big:hover .footer-cta__arrow { transform: translateX(.15em); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 40px; }
.footer-col__blurb { color: var(--ink-soft); margin-top: 18px; max-width: 32ch; }
.footer-col__title { font-size: .85rem; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-dim); margin-bottom: 18px; font-family: var(--font-d); }
.footer-col__list li { margin-bottom: 10px; color: var(--ink-soft); }
.footer-col__list a:hover { color: var(--ink); }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 70px; padding-top: 24px; border-top: 1px solid var(--line); color: var(--ink-dim); font-size: .9rem; flex-wrap: wrap; }

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero { padding-top: clamp(140px, 22vh, 240px); padding-bottom: clamp(40px,8vh,90px); position: relative; isolation: isolate; }
/* generative animated backdrop (injected by JS on [data-hero-bg] page heroes) */
.page-hero__bg { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 100vw; height: 100%; z-index: 0; display: block; pointer-events: none; -webkit-mask-image: linear-gradient(180deg, #000 55%, transparent); mask-image: linear-gradient(180deg, #000 55%, transparent); }
.page-hero[data-hero-bg] > *:not(.page-hero__bg) { position: relative; z-index: 1; }
.page-hero__title { font-size: clamp(2.6rem, 9vw, 7rem); }
.page-hero__lead { margin-top: 26px; }
.page-section h2 { margin-bottom: 24px; }
.prose { max-width: 70ch; color: var(--ink-soft); }
.prose p { margin-bottom: 1.1em; }
.prose h2, .prose h3 { color: var(--ink); margin: 1.6em 0 .6em; }

.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 22px; }
.feature { border: 1px solid var(--line); border-radius: var(--r); padding: 32px; background: var(--surface); transition: transform .5s var(--ease), border-color .4s; }
.feature:hover { transform: translateY(-6px); border-color: rgba(255,255,255,.25); }
.feature__icon { width: 46px; height: 46px; border-radius: 12px; margin-bottom: 22px; display: grid; place-items: center; color: var(--brand); background: rgba(23,180,200,.07); border: 1px solid rgba(23,180,200,.16); transition: color .4s var(--ease), border-color .4s var(--ease), background .4s var(--ease), transform .4s var(--ease); }
.feature__icon .ico { width: 24px; height: 24px; display: block; }
.feature:hover .feature__icon { color: var(--brand-2); border-color: rgba(23,180,200,.45); background: rgba(23,180,200,.12); transform: translateY(-2px); }

/* operational capability cards */
.caps { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; }
.cap { border: 1px solid var(--line); border-radius: var(--r); padding: 34px; background: var(--surface); display: flex; flex-direction: column; gap: 12px; transition: transform .5s var(--ease), border-color .4s; }
.cap:hover { transform: translateY(-6px); border-color: rgba(255,255,255,.25); }
.cap__title { font-size: 1.4rem; }
.cap__body { color: var(--ink-soft); flex: 1 1 auto; }
.cap__link { font-family: var(--font-d); color: var(--brand-2); display: inline-flex; align-items: center; gap: 8px; }
.cap__link span { transition: transform .35s var(--ease); }
.cap:hover .cap__link span { transform: translateX(6px); }
.feature__title { font-size: 1.3rem; }
.feature__body { color: var(--ink-soft); margin-top: 10px; }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,6vw,80px); align-items: center; }
.pricing { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 22px; }
.plan { border: 1px solid var(--line); border-radius: var(--r); padding: 34px; background: var(--surface); }
.plan--feat { border-color: var(--brand); box-shadow: 0 0 0 1px var(--brand), 0 30px 60px -30px rgba(23,180,200,.5); }
.plan__name { font-family: var(--font-d); font-weight: 600; font-size: 1.4rem; }
.plan__for { color: var(--ink-dim); margin-bottom: 20px; }
.plan__list li { color: var(--ink-soft); padding: 8px 0 8px 24px; position: relative; border-top: 1px solid var(--line); }
.plan__list li::before { content: "→"; position: absolute; left: 0; color: var(--brand-2); }

/* contact */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,6vw,70px); align-items: start; }
.contact-info__item { padding: 22px 0; border-top: 1px solid var(--line); }
.contact-info__label { color: var(--ink-dim); font-size: .85rem; letter-spacing: .12em; text-transform: uppercase; }
.contact-info__val { font-family: var(--font-d); font-size: 1.3rem; margin-top: 6px; }
.contact-map { margin-top: 40px; border-radius: var(--r); overflow: hidden; border: 1px solid var(--line); filter: grayscale(1) invert(.9) hue-rotate(180deg); }
.contact-map iframe { width: 100%; height: 360px; border: 0; }

/* CF7 / fallback form styling */
.wpcf7 input[type=text], .wpcf7 input[type=email], .wpcf7 input[type=tel], .wpcf7 textarea,
.cf-fallback input, .cf-fallback textarea {
	width: 100%; background: var(--surface); border: 1px solid var(--line); border-radius: 12px;
	padding: 16px 18px; color: var(--ink); font: inherit; margin-bottom: 14px; transition: border-color .3s;
}
.wpcf7 textarea, .cf-fallback textarea { resize: vertical; }
.wpcf7 input:focus, .wpcf7 textarea:focus, .cf-fallback input:focus, .cf-fallback textarea:focus { outline: none; border-color: var(--brand); }
.wpcf7 input[type=submit], .cf-fallback button {
	background: var(--ink); color: #0a0a0f; border: 0; border-radius: 100px; padding: 15px 30px;
	font-family: var(--font-d); font-weight: 500; cursor: pointer; transition: transform .3s, background .3s;
}
.wpcf7 input[type=submit]:hover, .cf-fallback button:hover { background: #fff; transform: translateY(-2px); }
.wpcf7-response-output { border-radius: 10px !important; margin: 10px 0 !important; }

/* ============================================================
   reveal / motion utilities
   ============================================================ */
[data-reveal] { opacity: 0; }
.word, .char { display: inline-block; }
.parallax { will-change: transform; }

/* ============================================================
   responsive
   ============================================================ */
@media (max-width: 1024px) {
	.footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
	.nav-desktop { display: none; }
	.nav-toggle { display: flex; }
	.split, .contact-grid, .about__body, .underhood { grid-template-columns: 1fr; }
	.work { grid-column: span 12 !important; }
	.footer-grid { grid-template-columns: 1fr; gap: 30px; }
	.service { grid-template-columns: 1fr; }
	.service__num { padding-top: 0; }
	.footer-bottom { flex-direction: column; gap: 8px; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
	[data-reveal] { opacity: 1 !important; }
	.hero__canvas { display: none; }
}
