/* ============================================================
   KAELO GLOBAL — page templates (About · Global Presence · Contact)
   Single stylesheet covering the three canonical content pages.
   ============================================================ */

.k-about,
.k-presence-page,
.k-contact { display: block; }

/* ============================================================
   SHARED HEROS — about / global presence / contact
   ============================================================ */
.k-ahero, .k-ghero, .k-chero {
	position: relative;
	min-height: 68vh;
	min-height: 68svh;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	color: var(--k-white);
	isolation: isolate;
}
.k-ahero__bg, .k-ghero__bg, .k-chero__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
}
.k-ahero__bg img, .k-ghero__bg img, .k-chero__bg img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.k-ahero__shade, .k-ghero__shade, .k-chero__shade {
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(180deg, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.68) 40%, rgba(0,0,0,0.96) 100%);
}
.k-ahero__inner, .k-ghero__inner, .k-chero__inner {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	width: 100%;
	padding: calc( var(--k-header-h) + var(--k-space-5) ) var(--k-bleed) var(--k-space-5);
	display: flex;
	flex-direction: column;
	gap: var(--k-space-2);
}
.k-ahero__inner .k-label,
.k-ghero__inner .k-label,
.k-chero__inner .k-label { color: var(--k-cyan); margin: 0; }

.k-ahero__title, .k-ghero__title, .k-chero__title {
	margin: 0;
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2.5rem, 1rem + 4.5vw, 5.5rem );
	line-height: 1.02;
	letter-spacing: -0.018em;
	color: var(--k-white);
	max-width: 22ch;
}
.k-ahero__sub, .k-ghero__sub, .k-chero__sub {
	max-width: 60ch;
	color: var(--k-white-60);
	font-size: var(--k-text-lg);
	line-height: var(--k-leading-snug);
	margin: 0;
}

/* ============================================================
   ABOUT — chronology
   ============================================================ */
.k-ach__head,
.k-ach__list {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-ach__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2rem, 1rem + 3vw, 3.75rem );
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	max-width: 22ch;
}
.k-ach__lead {
	max-width: 56ch;
	color: var(--k-ink-60);
	margin: 0 0 var(--k-space-5);
}
.k-ach__list {
	list-style: none;
	padding-inline: var(--k-bleed);
	margin: 0 auto;
	border-top: 1px solid var(--k-line);
}
.k-ach__row {
	display: grid;
	grid-template-columns: 9rem 1fr;
	gap: var(--k-space-4);
	padding: clamp( 1.6rem, 0.5rem + 1.6vw, 2.6rem ) 0;
	border-bottom: 1px solid var(--k-line);
	align-items: baseline;
}
.k-ach__period {
	font-family: var(--k-font-heading);
	font-weight: 500;
	font-size: clamp( 1.25rem, 0.7rem + 1.2vw, 2rem );
	color: var(--k-cyan-deep);
	letter-spacing: -0.01em;
}
.k-ach__rh {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.5rem, 0.7rem + 1.4vw, 2.25rem );
	line-height: 1.15;
	letter-spacing: -0.01em;
	margin: 0 0 var(--k-space-2);
	max-width: 36ch;
}
.k-ach__rl {
	font-size: var(--k-text-base);
	line-height: var(--k-leading-body);
	color: var(--k-ink-60);
	margin: 0;
	max-width: 60ch;
}

/* ============================================================
   ABOUT — operating principles (dark band)
   ============================================================ */
.k-ap__head,
.k-ap__list {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-ap__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2rem, 1rem + 3vw, 3.75rem );
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	color: var(--k-white);
	max-width: 22ch;
}
.k-ap__lead {
	max-width: 60ch;
	color: var(--k-white-60);
	margin: 0 0 var(--k-space-5);
}
.k-ap__list {
	list-style: none;
	margin: 0;
	border-top: 1px solid rgba(255,255,255,0.22);
}
.k-ap__row {
	display: grid;
	grid-template-columns: 5rem 1fr;
	gap: var(--k-space-3);
	padding: clamp( 1.6rem, 0.5rem + 1.6vw, 2.6rem ) 0;
	border-bottom: 1px solid rgba(255,255,255,0.22);
	align-items: baseline;
}
.k-ap__num {
	font-family: var(--k-font-heading);
	font-size: clamp( 1.5rem, 0.7rem + 1.6vw, 2.5rem );
	color: var(--k-cyan);
	letter-spacing: -0.01em;
}
.k-ap__rh {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.5rem, 0.7rem + 1.4vw, 2.25rem );
	line-height: 1.15;
	letter-spacing: -0.01em;
	margin: 0 0 var(--k-space-2);
	color: var(--k-white);
}
.k-ap__rl {
	font-size: var(--k-text-base);
	line-height: var(--k-leading-body);
	color: var(--k-white-60);
	margin: 0;
	max-width: 60ch;
}

/* ============================================================
   ABOUT — leadership + governance + partners (light)
   ============================================================ */
.k-aleader__inner,
.k-agov__head,
.k-agov__list,
.k-apart__head,
.k-apart__list,
.k-aroute__inner {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-aleader__h,
.k-agov__h,
.k-apart__h,
.k-aroute__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.75rem, 0.9rem + 2.4vw, 3.25rem );
	line-height: 1.15;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	max-width: 28ch;
}
.k-aleader__body {
	max-width: 65ch;
	color: var(--k-ink-60);
	margin: 0 0 var(--k-space-3);
	line-height: var(--k-leading-body);
}
.k-apart__lead {
	max-width: 60ch;
	color: var(--k-ink-60);
	margin: 0 0 var(--k-space-5);
}

.k-agov__list,
.k-apart__list {
	list-style: none;
	padding-inline: var(--k-bleed);
	margin: 0 auto;
	border-top: 1px solid var(--k-line);
}
.k-agov__row,
.k-apart__row {
	display: grid;
	grid-template-columns: 5rem 1fr;
	gap: var(--k-space-3);
	padding: clamp( 1.4rem, 0.5rem + 1.4vw, 2.2rem ) 0;
	border-bottom: 1px solid var(--k-line);
	align-items: baseline;
}
.k-agov__num,
.k-apart__num {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.25rem, 0.7rem + 1vw, 1.75rem );
	color: var(--k-cyan-deep);
}
.k-agov__name,
.k-apart__name {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.25rem, 0.7rem + 1.2vw, 1.875rem );
	line-height: 1.2;
	letter-spacing: -0.01em;
	margin: 0 0 var(--k-space-2);
}
.k-agov__lead,
.k-apart__lead {
	font-size: var(--k-text-base);
	line-height: var(--k-leading-body);
	color: var(--k-ink-60);
	margin: 0;
	max-width: 60ch;
}

/* ABOUT — route-out / read next */
.k-aroute__list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--k-line);
}
.k-aroute__list li { border-bottom: 1px solid var(--k-line); }
.k-aroute__link {
	display: grid;
	grid-template-columns: 1fr 2fr auto;
	gap: var(--k-space-3);
	align-items: baseline;
	padding: clamp( 1.4rem, 0.5rem + 1.2vw, 2rem ) 0;
	text-decoration: none;
	color: var(--k-ink);
	transition: padding-left var(--k-dur-fast) var(--k-ease);
}
.k-aroute__link:hover { padding-left: 0.5rem; color: var(--k-ink); }
.k-aroute__name {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.25rem, 0.7rem + 1.1vw, 1.75rem );
	letter-spacing: -0.01em;
}
.k-aroute__desc {
	font-size: var(--k-text-sm);
	color: var(--k-ink-60);
	line-height: var(--k-leading-body);
}
.k-aroute__arrow {
	font-family: var(--k-font-heading);
	color: var(--k-ink-40);
	transition: transform var(--k-dur-fast) var(--k-ease),
				color var(--k-dur-fast) var(--k-ease);
}
.k-aroute__link:hover .k-aroute__arrow { color: var(--k-cyan-deep); transform: translateX(0.4rem); }

/* ============================================================
   GLOBAL PRESENCE
   ============================================================ */
.k-gnums__head,
.k-gnums__grid {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-gnums__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2rem, 1rem + 3vw, 3.75rem );
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	max-width: 22ch;
}
.k-gnums__lead {
	max-width: 56ch;
	color: var(--k-ink-60);
	margin: 0 0 var(--k-space-5);
}
.k-gnums__grid {
	display: grid;
	grid-template-columns: repeat( 4, 1fr );
	gap: var(--k-space-3);
	border-top: 1px solid var(--k-line);
	padding-top: var(--k-space-3);
}
.k-gnums__cell {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}
.k-gnums__val {
	font-family: var(--k-font-heading);
	font-weight: 500;
	font-size: clamp( 2rem, 0.9rem + 2.5vw, 3.5rem );
	color: var(--k-cyan-deep);
	letter-spacing: -0.01em;
	line-height: 1;
}
.k-gnums__lbl {
	margin: 0;
	font-size: var(--k-text-xs);
	letter-spacing: var(--k-tracking-label);
	text-transform: uppercase;
	color: var(--k-ink-60);
	line-height: 1.4;
}

/* Each office section */
.k-goff__inner {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
	display: grid;
	grid-template-columns: 1fr 1.6fr;
	gap: var(--k-space-5);
	align-items: flex-start;
}
.k-goff__city {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2.5rem, 1rem + 4vw, 5rem );
	line-height: 1;
	letter-spacing: -0.018em;
	margin: var(--k-space-2) 0 0.5rem;
}
.k-goff__country {
	font-family: var(--k-font-body);
	font-size: var(--k-text-base);
	margin: 0 0 var(--k-space-3);
	opacity: 0.6;
}
.k-goff__meta {
	font-family: var(--k-font-body);
	font-size: var(--k-text-xs);
	letter-spacing: 0.06em;
	line-height: 1.7;
	margin: 0;
	opacity: 0.6;
	text-transform: uppercase;
}
.k-goff__lead {
	font-size: var(--k-text-lg);
	line-height: var(--k-leading-snug);
	margin: 0 0 var(--k-space-3);
	max-width: 60ch;
}
[data-k-theme="dark"] .k-goff__lead { color: var(--k-white-60); }
[data-k-theme="light"] .k-goff__lead { color: var(--k-ink); }

.k-goff__detail { margin-top: var(--k-space-3); }
.k-goff__label {
	font-size: var(--k-text-xs);
	letter-spacing: var(--k-tracking-label);
	text-transform: uppercase;
	margin: 0 0 0.4rem;
	opacity: 0.6;
}
.k-goff__divs {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem var(--k-space-3);
}
.k-goff__divs li {
	font-family: var(--k-font-heading);
	font-size: var(--k-text-base);
	letter-spacing: -0.01em;
}
.k-goff__covers {
	font-family: var(--k-font-body);
	margin: 0;
	font-size: var(--k-text-base);
	opacity: 0.85;
}

/* Capability map */
.k-gmap__head,
.k-gmap__grid {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-gmap__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.75rem, 0.9rem + 2.4vw, 3rem );
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
}
.k-gmap__lead { max-width: 56ch; color: var(--k-ink-60); margin: 0 0 var(--k-space-5); }
.k-gmap__grid {
	display: grid;
	grid-template-columns: repeat( 5, 1fr );
	gap: var(--k-space-3);
}
.k-gmap__cell {
	padding-top: var(--k-space-3);
	border-top: 1px solid var(--k-line);
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}
.k-gmap__num {
	font-family: var(--k-font-body);
	font-size: 0.6875rem;
	letter-spacing: 0.18em;
	color: var(--k-cyan-deep);
}
.k-gmap__name {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.05rem, 0.6rem + 0.7vw, 1.375rem );
	letter-spacing: -0.01em;
	margin: 0 0 0.5rem;
}
.k-gmap__where {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: var(--k-text-sm);
	color: var(--k-ink-60);
	line-height: 1.55;
}

/* ============================================================
   CONTACT
   ============================================================ */
.k-cintro__inner {
	max-width: 760px;
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-cintro__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.75rem, 0.9rem + 2.4vw, 3rem );
	line-height: 1.15;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	max-width: 24ch;
}
.k-cintro__inner p {
	font-size: var(--k-text-base);
	color: var(--k-ink-60);
	line-height: var(--k-leading-body);
	margin: 0 0 var(--k-space-3);
	max-width: 65ch;
}
.k-cintro__inner a {
	color: var(--k-cyan-deep);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

/* Routing list */
.k-croute__head,
.k-croute__list {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-croute__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2rem, 1rem + 3vw, 3.25rem );
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	max-width: 24ch;
}
.k-croute__lead {
	max-width: 60ch;
	color: var(--k-ink-60);
	margin: 0 0 var(--k-space-5);
}
.k-croute__list {
	list-style: none;
	margin: 0 auto;
	padding-inline: var(--k-bleed);
	border-top: 1px solid var(--k-line);
}
.k-croute__row { border-bottom: 1px solid var(--k-line); }
.k-croute__link {
	display: grid;
	grid-template-columns: 4rem 1fr auto;
	gap: var(--k-space-3);
	align-items: baseline;
	padding: clamp( 1.4rem, 0.5rem + 1.2vw, 2rem ) 0;
	text-decoration: none;
	color: var(--k-ink);
	transition: padding-left var(--k-dur-fast) var(--k-ease);
}
.k-croute__link:hover { padding-left: 0.5rem; color: var(--k-ink); }
.k-croute__num {
	font-family: var(--k-font-heading);
	font-size: clamp( 1.25rem, 0.7rem + 1vw, 1.75rem );
	color: var(--k-cyan-deep);
}
.k-croute__name {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.25rem, 0.7rem + 1.1vw, 1.75rem );
	margin: 0 0 0.5rem;
	letter-spacing: -0.01em;
}
.k-croute__lead {
	font-size: var(--k-text-sm);
	color: var(--k-ink-60);
	line-height: var(--k-leading-body);
	margin: 0 0 0.5rem;
	max-width: 60ch;
}
.k-croute__to {
	font-size: var(--k-text-xs);
	letter-spacing: var(--k-tracking-label);
	text-transform: uppercase;
	color: var(--k-ink-40);
	margin: 0;
}
.k-croute__arrow {
	font-family: var(--k-font-heading);
	color: var(--k-ink-40);
	transition: transform var(--k-dur-fast) var(--k-ease),
				color var(--k-dur-fast) var(--k-ease);
}
.k-croute__link:hover .k-croute__arrow { color: var(--k-cyan-deep); transform: translateX(0.4rem); }

/* Direct methods (dark) */
.k-cmethods__head,
.k-cmethods__grid {
	max-width: var(--k-container-wide);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-cmethods__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 2rem, 1rem + 3vw, 3.25rem );
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-5);
	max-width: 22ch;
}
.k-cmethods__grid {
	display: grid;
	grid-template-columns: repeat( 3, 1fr );
	gap: var(--k-space-3);
	border-top: 1px solid rgba(255,255,255,0.22);
	padding-top: var(--k-space-3);
}
.k-cmethods__cell {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}
.k-cmethods__label {
	font-size: var(--k-text-xs);
	letter-spacing: var(--k-tracking-label);
	text-transform: uppercase;
	color: var(--k-cyan);
	margin: 0;
}
.k-cmethods__val {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.25rem, 0.7rem + 1vw, 1.5rem );
	color: var(--k-white);
	margin: 0;
}
.k-cmethods__val a { color: var(--k-white); text-decoration: underline; text-decoration-color: var(--k-cyan); text-underline-offset: 4px; }
.k-cmethods__val a:hover { color: var(--k-cyan); }
.k-cmethods__note {
	font-size: var(--k-text-sm);
	color: var(--k-white-60);
	margin: 0;
	max-width: 36ch;
	line-height: var(--k-leading-body);
}

/* What we do not do */
.k-cdont__inner {
	max-width: 760px;
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-cdont__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.75rem, 0.9rem + 2.4vw, 2.75rem );
	line-height: 1.15;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-3);
	max-width: 28ch;
}
.k-cdont__list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--k-line);
}
.k-cdont__list li {
	padding: var(--k-space-2) 0;
	border-bottom: 1px solid var(--k-line);
	font-size: var(--k-text-base);
	color: var(--k-ink-60);
	line-height: var(--k-leading-body);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media ( max-width: 980px ) {
	.k-ach__row    { grid-template-columns: 7rem 1fr; gap: var(--k-space-3); }
	.k-ap__row     { grid-template-columns: 3.5rem 1fr; }
	.k-agov__row,
	.k-apart__row  { grid-template-columns: 3.5rem 1fr; }
	.k-aroute__link{ grid-template-columns: 1fr auto; grid-template-areas: "name arrow" "desc arrow"; }
	.k-aroute__name { grid-area: name; }
	.k-aroute__desc { grid-area: desc; }
	.k-aroute__arrow{ grid-area: arrow; align-self: center; }

	.k-gnums__grid    { grid-template-columns: repeat( 2, 1fr ); }
	.k-goff__inner    { grid-template-columns: 1fr; gap: var(--k-space-3); }
	.k-gmap__grid     { grid-template-columns: repeat( 2, 1fr ); }

	.k-croute__link   { grid-template-columns: 3rem 1fr auto; }
	.k-cmethods__grid { grid-template-columns: 1fr; gap: var(--k-space-4); border-top: 0; padding-top: 0; }
	.k-cmethods__cell { border-top: 1px solid rgba(255,255,255,0.22); padding-top: var(--k-space-3); }
}

/* ============================================================
   Contact form (on /contact/)
   ============================================================ */

.k-cform__head,
.k-cform__form,
.k-cform__notice {
	max-width: var(--k-container-text);
	margin-inline: auto;
	padding-inline: var(--k-bleed);
}
.k-cform__h {
	font-family: var(--k-font-heading);
	font-weight: 400;
	font-size: clamp( 1.75rem, 0.9rem + 2.4vw, 2.75rem );
	line-height: 1.15;
	letter-spacing: -0.015em;
	margin: var(--k-space-2) 0 var(--k-space-2);
	max-width: 28ch;
}
.k-cform__sub {
	font-family: var(--k-font-body);
	font-size: var(--k-text-base);
	line-height: var(--k-leading-body);
	color: var(--k-ink-60);
	margin: 0 0 var(--k-space-4);
	max-width: 60ch;
}

.k-cform__notice {
	border-left: 2px solid var(--k-ink);
	padding: var(--k-space-2) var(--k-space-3);
	margin-bottom: var(--k-space-3);
	background: var(--k-bone);
	font-family: var(--k-font-body);
	font-size: var(--k-text-base);
	line-height: 1.5;
}
.k-cform__notice--ok  { border-left-color: var(--k-cyan-deep); background: rgba( 3, 241, 255, 0.06 ); }
.k-cform__notice--err { border-left-color: #b9301f; background: rgba( 185, 48, 31, 0.06 ); }
.k-cform__notice a    { color: var(--k-cyan-deep); }

.k-cform__form {
	display: grid;
	gap: var(--k-space-3);
}
.k-cform__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--k-space-3);
}
.k-cform__field {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.k-cform__field--full {
	grid-column: 1 / -1;
}
.k-cform__field label {
	font-family: var(--k-font-body);
	font-weight: 500;
	font-size: 0.75rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--k-ink);
}
.k-cform__opt {
	font-weight: 400;
	letter-spacing: 0.12em;
	color: var(--k-ink-60);
	text-transform: none;
	margin-left: 0.5rem;
}
.k-cform__field input[type="text"],
.k-cform__field input[type="email"],
.k-cform__field select,
.k-cform__field textarea {
	width: 100%;
	padding: 0.85rem 1rem;
	font-family: var(--k-font-body);
	font-size: 1rem;
	line-height: 1.5;
	color: var(--k-ink);
	background: var(--k-paper);
	border: 1px solid var(--k-line);
	border-radius: 0;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.k-cform__field textarea {
	resize: vertical;
	min-height: 8rem;
}
.k-cform__field input:focus,
.k-cform__field select:focus,
.k-cform__field textarea:focus {
	outline: none;
	border-color: var(--k-cyan-deep);
	box-shadow: 0 0 0 3px rgba( 3, 241, 255, 0.18 );
}
.k-cform__field.is-error input,
.k-cform__field.is-error select,
.k-cform__field.is-error textarea {
	border-color: #b9301f;
	box-shadow: 0 0 0 3px rgba( 185, 48, 31, 0.12 );
}
.k-cform__hint {
	font-family: var(--k-font-body);
	font-size: 0.75rem;
	color: var(--k-ink-60);
	margin: 0;
}

.k-cform__hp {
	position: absolute;
	left: -10000px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.k-cform__foot {
	display: grid;
	gap: var(--k-space-2);
	margin-top: var(--k-space-2);
}
.k-cform__foot .k-btn {
	justify-self: start;
}
.k-cform__legal {
	font-family: var(--k-font-body);
	font-size: 0.8125rem;
	color: var(--k-ink-60);
	margin: 0;
	max-width: 60ch;
}
.k-cform__legal a { color: var(--k-cyan-deep); }

@media ( max-width: 720px ) {
	.k-cform__grid { grid-template-columns: 1fr; }
}

@media ( max-width: 560px ) {
	.k-ahero__title, .k-ghero__title, .k-chero__title { font-size: clamp( 2rem, 9vw, 2.75rem ); }
	.k-ahero__sub, .k-ghero__sub, .k-chero__sub       { font-size: var(--k-text-base); }

	.k-ach__row    { grid-template-columns: 1fr; gap: 0.5rem; padding: var(--k-space-3) 0; }
	.k-ap__row     { grid-template-columns: 2.5rem 1fr; padding: var(--k-space-3) 0; }
	.k-agov__row,
	.k-apart__row  { grid-template-columns: 2.5rem 1fr; padding: var(--k-space-3) 0; }

	.k-gnums__grid    { grid-template-columns: 1fr 1fr; gap: var(--k-space-3); }
	.k-gmap__grid     { grid-template-columns: 1fr; }
	.k-croute__link   { grid-template-columns: 2.5rem 1fr auto; column-gap: var(--k-space-2); padding: var(--k-space-3) 0; }
}
