/* ==========================================================================
   Grow Your Limo — luxury black + gold design system
   Mobile-first. No page builders. Pure CSS.
   ========================================================================== */

:root {
	--gyl-black:    #060606;
	--gyl-graphite: #111111;
	--gyl-charcoal: #1A1A1A;
	--gyl-gold:     #D4AF37;
	--gyl-gold-soft:#F3D58A;
	--gyl-ivory:    #F7F1E3;
	--gyl-muted:    #B8B0A0;
	--gyl-border:   rgba(212,175,55,.20);
	--gyl-border-strong: rgba(212,175,55,.45);

	--gyl-font-display: 'Playfair Display', 'Boska', Georgia, serif;
	--gyl-font-body:    'Inter', 'Satoshi', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--gyl-font-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

	--gyl-radius:    14px;
	--gyl-radius-sm: 10px;
	--gyl-radius-lg: 22px;

	--gyl-shadow-card: 0 1px 0 rgba(255,255,255,.04) inset, 0 30px 60px rgba(0,0,0,.6);
	--gyl-shadow-glow: 0 0 0 1px rgba(212,175,55,.18), 0 30px 80px rgba(212,175,55,.10);

	--gyl-container: 1200px;

	--gyl-grad-gold: linear-gradient(90deg,#D4AF37 0%,#F3D58A 50%,#D4AF37 100%);
}

/* ---- reset --------------------------------------------------------------- */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body {
	margin:0;
	background: var(--gyl-black);
	color: var(--gyl-ivory);
	font-family: var(--gyl-font-body);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
img,svg,video { max-width:100%; display:block; height:auto; }
a { color: var(--gyl-gold); text-decoration: none; }
a:hover { color: var(--gyl-gold-soft); text-decoration: underline; }
a:focus-visible { outline: 2px solid var(--gyl-gold); outline-offset: 3px; border-radius: 4px; }
:focus:not(:focus-visible) { outline: none; }
button { font-family: inherit; }
hr { border:0; border-top:1px solid var(--gyl-border); margin:32px 0; }

::selection { background: var(--gyl-gold); color: var(--gyl-black); }

/* ---- a11y ---------------------------------------------------------------- */
.gyl-skip {
	position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.gyl-skip:focus {
	position:fixed; top:12px; left:12px; width:auto; height:auto; padding:8px 14px;
	background:var(--gyl-gold); color:var(--gyl-black); border-radius:8px; z-index: 9999;
}
.gyl-sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ---- typography ---------------------------------------------------------- */
.gyl-display, .gyl-h1, .gyl-h2, .gyl-h3 {
	font-family: var(--gyl-font-display);
	font-weight: 600;
	letter-spacing: -.01em;
	color: var(--gyl-ivory);
	margin: 0 0 .5em;
	line-height: 1.08;
}
.gyl-display {
	font-size: clamp(36px, 6.2vw, 76px);
	letter-spacing: -.02em;
}
.gyl-h1 { font-size: clamp(28px, 3.8vw, 48px); }
.gyl-h2 { font-size: clamp(24px, 3vw, 36px); }
.gyl-h3 { font-size: clamp(20px, 2vw, 24px); }

.gyl-grad {
	background: var(--gyl-grad-gold);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.gyl-kicker {
	display:inline-block;
	font-family: var(--gyl-font-mono);
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--gyl-gold);
	padding: 6px 12px;
	border:1px solid var(--gyl-border);
	border-radius: 999px;
	background: rgba(212,175,55,.04);
	margin-bottom: 18px;
}

.gyl-lead {
	color: var(--gyl-muted);
	font-size: clamp(16px, 1.6vw, 19px);
	max-width: 64ch;
	margin: 0 0 24px;
}

.gyl-muted { color: var(--gyl-muted); }

/* ---- container ----------------------------------------------------------- */
.gyl-container {
	max-width: var(--gyl-container);
	margin-inline: auto;
	padding-inline: 22px;
}
@media (min-width: 768px) { .gyl-container { padding-inline: 32px; } }

/* ---- buttons ------------------------------------------------------------- */
.gyl-btn {
	display:inline-flex; align-items:center; justify-content:center;
	gap:8px;
	padding: 14px 22px;
	font-weight: 600;
	font-size: 15px;
	letter-spacing: .01em;
	border-radius: 999px;
	border:1px solid transparent;
	cursor: pointer;
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
	text-decoration: none;
	white-space: nowrap;
}
.gyl-btn:hover { text-decoration: none; transform: translateY(-1px); }
.gyl-btn--sm { padding: 10px 16px; font-size: 14px; }
.gyl-btn--gold {
	background: var(--gyl-gold);
	color: var(--gyl-black);
	box-shadow: 0 1px 0 rgba(255,255,255,.4) inset, 0 16px 36px rgba(212,175,55,.22);
}
.gyl-btn--gold:hover { background: var(--gyl-gold-soft); color: var(--gyl-black); box-shadow: 0 1px 0 rgba(255,255,255,.5) inset, 0 22px 44px rgba(212,175,55,.30); }
.gyl-btn--ghost {
	background: transparent;
	color: var(--gyl-ivory);
	border-color: var(--gyl-border-strong);
}
.gyl-btn--ghost:hover { background: rgba(212,175,55,.06); color: var(--gyl-gold); border-color: var(--gyl-gold); }

.gyl-cta-pair { display:flex; flex-wrap:wrap; gap:12px; margin-top:8px; }
.gyl-cta-pair--hero { margin-top: 28px; }

/* ============================================================
   HEADER — 48px sticky bar + mega-menu panels
   ============================================================ */

:root { --gyl-header-h: 88px; }

.gyl-header {
	position: sticky;
	top: 0;
	z-index: 60;
	height: var(--gyl-header-h);
	background: var(--gyl-black);
	border-bottom: 1px solid var(--gyl-border);
}
.admin-bar .gyl-header { top: 32px; }
@media (max-width: 782px) { .admin-bar .gyl-header { top: 46px; } }

.gyl-header__bar {
	height: var(--gyl-header-h);
	max-width: 1360px;
	margin-inline: auto;
	padding-inline: 24px;
	display: flex;
	align-items: center;
	gap: 16px;
}
.gyl-logo {
	display: inline-flex; align-items: center; gap: 10px;
	color: var(--gyl-ivory);
	text-decoration: none;
	flex-shrink: 0;
	max-height: 56px;
}
.gyl-logo:hover { text-decoration: none; color: var(--gyl-gold-soft); }

/* WP custom_logo (rendered inside .gyl-header__bar). The_custom_logo() outputs
   <a class="custom-logo-link"><img class="custom-logo"></a> — we target those
   classes directly because nested <a> tags are stripped by browsers. */
.gyl-header__bar .custom-logo-link {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	height: 80px;
	max-height: 80px;
	text-decoration: none;
}
.gyl-header__bar .custom-logo {
	max-height: 80px !important;
	width: auto !important;
	height: auto;
	display: block;
	object-fit: contain;
}
@media (max-width: 600px) {
	.gyl-header__bar .custom-logo-link,
	.gyl-header__bar .custom-logo { max-height: 56px !important; height: 56px; }
}

/* Footer logo (image variant — when gyl_footer_logo is set in Customizer) */
.gyl-logo--footer-img {
	display: inline-block;
	max-width: 200px;
	max-height: 100px;
	margin-bottom: 4px;
	overflow: hidden;
	border-radius: 12px;
}
.gyl-logo--footer-img img {
	width: 100%;
	height: auto;
	display: block;
	max-height: 100px;
	object-fit: contain;
	background: #000;
	border-radius: 12px;
}
.gyl-logo__mark {
	display: inline-grid; place-items: center;
	width: 38px; height: 38px;
	border-radius: 9px;
	background: linear-gradient(135deg, var(--gyl-gold) 0%, var(--gyl-gold-soft) 100%);
	color: var(--gyl-black);
	font-family: var(--gyl-font-display);
	font-weight: 700;
	font-size: 13px;
	letter-spacing: -.02em;
}
.gyl-logo__word {
	font-family: var(--gyl-font-display);
	font-size: 18px;
	letter-spacing: .01em;
	white-space: nowrap;
}

/* Nav (desktop only) — CENTERED in the header bar.
   Layout via CSS `order`:
     [logo] (left, order 1)
     [nav]  (center, order 2, flex: 1)
     [actions/search] (right, order 3)  */
.gyl-nav {
	display: none;
	flex: 1 1 auto;
	justify-content: center;
	order: 2;
}
@media (min-width: 1024px) { .gyl-nav { display: flex; } }

/* Logo on the LEFT */
.gyl-header__bar > .gyl-logo,
.gyl-header__bar > .custom-logo-link {
	order: 1;
}

/* Search trigger / burger on the RIGHT */
.gyl-header__actions {
	order: 3;
	margin-left: 0;
}

.gyl-nav__list {
	display: flex;
	align-items: center;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
}
.gyl-nav__item { position: relative; height: var(--gyl-header-h); display: flex; align-items: center; }
.gyl-nav__link {
	display: inline-flex;
	align-items: center;
	height: var(--gyl-header-h);
	padding: 0 14px;
	color: var(--gyl-ivory);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: .01em;
	text-decoration: none;
	transition: color .2s ease;
	white-space: nowrap;
	position: relative;
}
.gyl-nav__link:hover { color: var(--gyl-gold); text-decoration: none; }
.gyl-nav__item--mega.is-active .gyl-nav__link { color: var(--gyl-gold); }
.gyl-nav__item--mega.is-active .gyl-nav__link::after {
	content: "";
	position: absolute;
	left: 14px; right: 14px; bottom: 0;
	height: 2px;
	background: var(--gyl-gold);
}

/* Header right-side actions */
.gyl-header__actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
	margin-left: auto;
}
/* Search trigger (right side) */
.gyl-search-trigger {
	display: none;
	align-items: center;
	gap: 10px;
	height: 32px;
	padding: 0 12px;
	background: rgba(255,255,255,.04);
	border: 1px solid var(--gyl-border);
	border-radius: 999px;
	color: var(--gyl-muted);
	font-family: inherit;
	font-size: 13px;
	cursor: pointer;
	transition: background .2s ease, border-color .2s ease, color .2s ease;
	min-width: 220px;
}
.gyl-search-trigger:hover {
	background: rgba(212,175,55,.06);
	border-color: var(--gyl-border-strong);
	color: var(--gyl-ivory);
}
.gyl-search-trigger__icon { color: var(--gyl-gold); flex-shrink: 0; }
.gyl-search-trigger__label {
	flex: 1;
	text-align: left;
	letter-spacing: .01em;
}
.gyl-search-trigger__kbd {
	display: inline-flex;
	align-items: center;
	gap: 1px;
	padding: 2px 6px;
	background: var(--gyl-charcoal);
	border: 1px solid var(--gyl-border);
	border-radius: 6px;
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	color: var(--gyl-muted);
	letter-spacing: .04em;
}
.gyl-search-trigger__kbd .gyl-kbd-mod { font-size: 12px; }
@media (min-width: 1024px) { .gyl-search-trigger { display: inline-flex; } }

/* Mobile: small icon-only search trigger */
.gyl-search-trigger--mobile,
@media (max-width: 1023.98px) {
	.gyl-search-trigger {
		display: inline-flex;
		min-width: 0;
		padding: 0;
		width: 36px;
		height: 36px;
		justify-content: center;
		background: transparent;
		border: 0;
	}
	.gyl-search-trigger__label,
	.gyl-search-trigger__kbd { display: none; }
	.gyl-search-trigger__icon { color: var(--gyl-ivory); }
}

/* Hamburger */
.gyl-burger {
	display: inline-flex; flex-direction: column; justify-content: space-between;
	width: 32px; height: 24px;
	background: transparent;
	border: 0;
	padding: 6px 0;
	cursor: pointer;
}
.gyl-burger span { display: block; width: 22px; height: 1.5px; background: var(--gyl-ivory); border-radius: 2px; transition: transform .2s ease, opacity .2s ease; margin-left: auto; margin-right: auto; }
@media (min-width: 1024px) { .gyl-burger { display: none; } }

/* ============================================================
   MEGA-MENU PANELS — full-width, fixed below header, fade+slide
   ============================================================ */
.gyl-mega {
	position: fixed;
	left: 0; right: 0;
	top: var(--gyl-header-h);
	z-index: 50;
	width: 100vw;
	background: var(--gyl-black);
	border-bottom: 1px solid var(--gyl-border);
	box-shadow: 0 30px 60px rgba(0,0,0,.5);
	opacity: 0;
	transform: translateY(-12px);
	pointer-events: none;
	transition: opacity .25s cubic-bezier(.4,0,.2,1), transform .25s cubic-bezier(.4,0,.2,1);
}
.admin-bar .gyl-mega { top: calc(var(--gyl-header-h) + 32px); }
@media (max-width: 782px) { .admin-bar .gyl-mega { top: calc(var(--gyl-header-h) + 46px); } }

.gyl-mega.is-open {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.gyl-mega[hidden] { display: none; }
.gyl-mega.is-open[hidden] { display: block; }

.gyl-mega__inner {
	max-width: 1200px;
	margin-inline: auto;
	padding: 40px 32px 32px;
}
.gyl-mega__cols {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
}
.gyl-mega__col { min-width: 0; }
.gyl-mega__heading {
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--gyl-gold);
	margin: 0 0 14px;
}
.gyl-mega__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.gyl-mega__list li a {
	display: block;
	padding: 8px 0;
	color: var(--gyl-ivory);
	font-family: var(--gyl-font-display);
	font-size: 17px;
	font-weight: 500;
	letter-spacing: -.005em;
	text-decoration: none;
	transition: color .15s ease, transform .15s ease;
}
.gyl-mega__list li a:hover {
	color: var(--gyl-gold);
	transform: translateX(2px);
	text-decoration: none;
}

.gyl-mega__footer {
	margin-top: 28px;
	padding-top: 20px;
	border-top: 1px solid var(--gyl-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}
.gyl-mega__view-all {
	font-family: var(--gyl-font-mono);
	font-size: 12px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--gyl-gold);
	text-decoration: none;
}
.gyl-mega__view-all:hover { color: var(--gyl-gold-soft); text-decoration: none; }
.gyl-mega__cta {
	display: inline-flex;
	align-items: center;
	height: 36px;
	padding: 0 18px;
	background: var(--gyl-gold);
	color: var(--gyl-black);
	font-weight: 600;
	font-size: 13px;
	border-radius: 999px;
	text-decoration: none;
	transition: background .2s ease, transform .15s ease;
}
.gyl-mega__cta:hover { background: var(--gyl-gold-soft); color: var(--gyl-black); transform: translateY(-1px); text-decoration: none; }

@media (max-width: 1023.98px) {
	.gyl-mega { display: none !important; }
}

/* ============================================================
   SEARCH COMMAND PALETTE — ⌘K / Ctrl+K
   ============================================================ */
.gyl-search {
	position: fixed; inset: 0; z-index: 90;
	pointer-events: none;
}
.gyl-search[hidden] { display: none; }
.gyl-search[aria-hidden="false"][hidden] { display: block; }
.gyl-search[aria-hidden="false"] { pointer-events: auto; }

.gyl-search__overlay {
	position: absolute; inset: 0;
	background: rgba(6,6,6,.78);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	opacity: 0;
	transition: opacity .2s ease;
}
.gyl-search[aria-hidden="false"] .gyl-search__overlay { opacity: 1; }

.gyl-search__panel {
	position: relative;
	max-width: 640px;
	margin: 12vh auto 0;
	background: var(--gyl-graphite);
	border: 1px solid var(--gyl-border-strong);
	border-radius: 16px;
	box-shadow: 0 40px 80px rgba(0,0,0,.6);
	overflow: hidden;
	transform: translateY(-8px) scale(.98);
	opacity: 0;
	transition: transform .2s ease, opacity .2s ease;
}
.gyl-search[aria-hidden="false"] .gyl-search__panel {
	transform: translateY(0) scale(1);
	opacity: 1;
}
@media (max-width: 640px) {
	.gyl-search__panel { margin: 8vh 16px 0; }
}

.gyl-search__form {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--gyl-border);
}
.gyl-search__icon { color: var(--gyl-gold); flex-shrink: 0; }
.gyl-search__input {
	flex: 1;
	background: transparent;
	border: 0;
	outline: 0;
	color: var(--gyl-ivory);
	font-family: inherit;
	font-size: 16px;
	padding: 4px 0;
}
.gyl-search__input::placeholder { color: var(--gyl-muted); }
.gyl-search__esc {
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 4px;
}
.gyl-search__esc kbd {
	display: inline-flex;
	align-items: center;
	padding: 3px 8px;
	background: var(--gyl-charcoal);
	border: 1px solid var(--gyl-border);
	border-radius: 6px;
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	color: var(--gyl-muted);
	text-transform: uppercase;
	letter-spacing: .08em;
}

.gyl-search__body {
	max-height: 56vh;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.gyl-search__group {
	padding: 10px 8px 12px;
	border-bottom: 1px solid var(--gyl-border);
}
.gyl-search__group:last-child { border-bottom: 0; }
.gyl-search__group-label {
	display: block;
	padding: 6px 12px;
	font-family: var(--gyl-font-mono);
	font-size: 10px;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--gyl-muted);
}
.gyl-search__group a,
.gyl-search__results a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 12px;
	color: var(--gyl-ivory);
	text-decoration: none;
	border-radius: 8px;
	font-size: 14px;
	transition: background .12s ease, color .12s ease;
	gap: 12px;
}
.gyl-search__group a:hover,
.gyl-search__group a.is-active,
.gyl-search__results a:hover,
.gyl-search__results a.is-active {
	background: rgba(212,175,55,.08);
	color: var(--gyl-gold);
	text-decoration: none;
}
.gyl-search__group a > span:first-child,
.gyl-search__results a > span:first-child {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.gyl-search__hint {
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	color: var(--gyl-muted);
	letter-spacing: .04em;
	flex-shrink: 0;
}

.gyl-search__results { padding: 10px 8px; }
.gyl-search__empty { padding: 20px; text-align: center; color: var(--gyl-muted); font-size: 14px; }
.gyl-search__empty a { color: var(--gyl-gold); }

.gyl-search__foot {
	display: flex;
	gap: 16px;
	padding: 10px 16px;
	border-top: 1px solid var(--gyl-border);
	background: rgba(0,0,0,.3);
	font-size: 11px;
	color: var(--gyl-muted);
	letter-spacing: .04em;
}
.gyl-search__foot kbd {
	display: inline-flex;
	align-items: center;
	margin-right: 4px;
	padding: 2px 6px;
	background: var(--gyl-charcoal);
	border: 1px solid var(--gyl-border);
	border-radius: 5px;
	font-family: var(--gyl-font-mono);
	font-size: 10px;
}
@media (max-width: 480px) {
	.gyl-search__foot { display: none; }
}

/* ============================================================
   MOBILE SHEET — slide in from right
   ============================================================ */
.gyl-sheet {
	position: fixed; inset: 0; z-index: 80;
	pointer-events: none;
}
.gyl-sheet[aria-hidden="false"] { pointer-events: auto; }
.gyl-sheet[hidden] { display: none; }
.gyl-sheet[aria-hidden="false"][hidden] { display: block; }

.gyl-sheet__overlay {
	position: absolute; inset: 0;
	background: rgba(6,6,6,.7);
	opacity: 0;
	transition: opacity .3s ease;
}
.gyl-sheet[aria-hidden="false"] .gyl-sheet__overlay { opacity: 1; }

.gyl-sheet__panel {
	position: absolute;
	top: 0; right: 0; bottom: 0;
	width: min(360px, 92vw);
	background: var(--gyl-graphite);
	border-left: 1px solid var(--gyl-border-strong);
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform .35s cubic-bezier(.4,0,.2,1);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}
.gyl-sheet[aria-hidden="false"] .gyl-sheet__panel { transform: translateX(0); }

.gyl-sheet__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 16px 20px;
	border-bottom: 1px solid var(--gyl-border);
	flex-shrink: 0;
}
.gyl-sheet__close {
	background: transparent;
	border: 0;
	color: var(--gyl-ivory);
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	padding: 0 4px;
	transition: color .15s ease;
}
.gyl-sheet__close:hover { color: var(--gyl-gold); }

.gyl-sheet__nav { padding: 16px 0; flex: 1; }
.gyl-sheet__group { border-bottom: 1px solid var(--gyl-border); }
.gyl-sheet__summary {
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 20px;
	color: var(--gyl-ivory);
	font-family: var(--gyl-font-display);
	font-size: 18px;
	font-weight: 500;
}
.gyl-sheet__summary::-webkit-details-marker { display: none; }
.gyl-sheet__summary span { color: var(--gyl-gold); font-size: 22px; transition: transform .2s ease; }
.gyl-sheet__group[open] .gyl-sheet__summary span { transform: rotate(45deg); }
.gyl-sheet__sub { padding: 4px 20px 18px; }
.gyl-sheet__sub-hub {
	display: block;
	margin-bottom: 14px;
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--gyl-gold);
	text-decoration: none;
}
.gyl-sheet__sub-col { margin-bottom: 14px; }
.gyl-sheet__sub-heading {
	display: block;
	font-family: var(--gyl-font-mono);
	font-size: 10px;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--gyl-muted);
	margin-bottom: 6px;
}
.gyl-sheet__sub a {
	display: block;
	padding: 6px 0;
	color: var(--gyl-ivory);
	font-size: 14px;
	text-decoration: none;
}
.gyl-sheet__sub a:hover { color: var(--gyl-gold); text-decoration: none; }
.gyl-sheet__flat {
	display: block;
	padding: 16px 20px;
	border-bottom: 1px solid var(--gyl-border);
	color: var(--gyl-ivory);
	font-family: var(--gyl-font-display);
	font-size: 18px;
	font-weight: 500;
	text-decoration: none;
}
.gyl-sheet__flat:hover { color: var(--gyl-gold); text-decoration: none; }

.gyl-sheet__foot {
	padding: 16px 20px calc(16px + env(safe-area-inset-bottom, 0px));
	display: grid;
	gap: 8px;
	border-top: 1px solid var(--gyl-border);
	flex-shrink: 0;
}
.gyl-sheet__foot .gyl-btn { width: 100%; justify-content: center; }
.gyl-logo--sheet .gyl-logo__mark { width: 32px; height: 32px; font-size: 12px; border-radius: 8px; }
.gyl-logo--sheet .gyl-logo__word { font-size: 17px; }

/* ---- hero (with optional featured-image backdrop) ----------------------- */
.gyl-hero--has-bg {
	background:
		linear-gradient(180deg, rgba(6,6,6,.78) 0%, rgba(6,6,6,.84) 50%, rgba(15,14,12,.96) 100%),
		var(--gyl-hero-bg, none) center/cover no-repeat,
		#0F0E0C !important;
	color: #F7F1E3;
	border-bottom: 1px solid rgba(212,175,55,.15);
}
.gyl-hero--has-bg .gyl-display,
.gyl-hero--has-bg .gyl-h1 { color: #F7F1E3 !important; }
.gyl-hero--has-bg .gyl-lead { color: #D8D2C2 !important; max-width: 60ch; margin-inline: auto; }
.gyl-hero--has-bg .gyl-kicker {
	color: var(--gyl-gold) !important;
	background: rgba(212,175,55,.08);
	border-color: rgba(212,175,55,.35);
}
.gyl-hero--has-bg .gyl-btn--ghost {
	color: #F7F1E3 !important;
	background: rgba(255,255,255,.08);
	border-color: rgba(247,241,227,.7);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.gyl-hero--has-bg .gyl-btn--ghost:hover {
	background: rgba(212,175,55,.18);
	color: var(--gyl-gold) !important;
	border-color: var(--gyl-gold);
}
/* Light-theme override is unnecessary because gyl-hero--has-bg explicitly sets dark.
   Just make sure the body's light-theme overrides DON'T override our dark hero. */
body.gyl-theme-light .gyl-hero--has-bg .gyl-display,
body.gyl-theme-light .gyl-hero--has-bg .gyl-h1 { color: #F7F1E3 !important; }
body.gyl-theme-light .gyl-hero--has-bg .gyl-lead { color: #D8D2C2 !important; }
body.gyl-theme-light .gyl-hero--has-bg .gyl-kicker { color: var(--gyl-gold) !important; }

/* ---- hero ---------------------------------------------------------------- */
.gyl-hero {
	position: relative;
	overflow: hidden;
	padding: clamp(64px, 9vw, 132px) 0 clamp(56px, 7vw, 96px);
	background:
		radial-gradient(1200px 600px at 80% -10%, rgba(212,175,55,.12), transparent 50%),
		radial-gradient(900px 500px at 10% 20%, rgba(212,175,55,.05), transparent 60%),
		var(--gyl-black);
}
.gyl-hero__bg { position:absolute; inset:0; pointer-events:none; }
.gyl-hero__glow {
	position:absolute; left:-15%; top:-15%;
	width:60vw; aspect-ratio:1;
	background: radial-gradient(closest-side, rgba(212,175,55,.18), transparent 70%);
	filter: blur(20px);
}
.gyl-hero__grid {
	position:absolute; inset:0;
	background-image:
		linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
	background-size: 80px 80px;
	mask-image: radial-gradient(ellipse at top, rgba(0,0,0,.6), rgba(0,0,0,0) 70%);
	-webkit-mask-image: radial-gradient(ellipse at top, rgba(0,0,0,.6), rgba(0,0,0,0) 70%);
}
.gyl-hero__inner { position:relative; z-index:1; }
.gyl-hero--home .gyl-display { max-width: 18ch; }
.gyl-hero__chips {
	display:flex; flex-wrap:wrap; gap: 8px;
	margin: 32px 0 0; padding:0; list-style:none;
}
.gyl-hero__chips li {
	font-family: var(--gyl-font-mono);
	font-size: 12px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--gyl-muted);
	padding: 8px 12px;
	border-radius: 999px;
	border:1px solid var(--gyl-border);
	background: rgba(255,255,255,.02);
}

/* ---- sections ------------------------------------------------------------ */
.gyl-section { padding: clamp(56px, 7vw, 96px) 0; position: relative; }
.gyl-section--prose { padding-top: 32px; }
.gyl-section__head { max-width: 64ch; margin-bottom: 40px; }
.gyl-section__head .gyl-lead { margin-top: 8px; }

/* ---- logo strip ---------------------------------------------------------- */
.gyl-logo-strip {
	padding: 36px 0;
	border-block: 1px solid var(--gyl-border);
	background: var(--gyl-graphite);
}
.gyl-logo-strip__lead {
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--gyl-muted);
	margin: 0 0 24px;
	text-align: center;
}
.gyl-logo-strip__row {
	display: flex;
	flex-wrap: wrap;
	gap: 16px 40px;
	align-items: center;
	justify-content: center;
}
.gyl-logo-strip__item {
	display: inline-flex;
	align-items: center;
	color: var(--gyl-ivory);
	opacity: .65;
	text-decoration: none;
	transition: opacity .2s ease, color .2s ease, transform .15s ease;
	font-family: var(--gyl-font-display);
	font-size: 19px;
	letter-spacing: -.005em;
	white-space: nowrap;
	line-height: 1;
}
.gyl-logo-strip__item:hover {
	opacity: 1;
	color: var(--gyl-gold);
	transform: translateY(-1px);
	text-decoration: none;
}
.gyl-logo-strip__item .b { font-weight: 700; }
.gyl-logo-strip__item .mono { font-family: var(--gyl-font-mono); font-size: 14px; letter-spacing: .04em; }

/* Brand-flavour overrides — cheap typographic identity */
.gyl-brand-limoanywhere span:first-child { font-weight: 300; font-style: italic; opacity: .85; margin-right: 1px; }
.gyl-brand-moovs .b { font-weight: 800; letter-spacing: -.04em; text-transform: lowercase; }
.gyl-brand-hudson .b { font-weight: 700; letter-spacing: .14em; font-size: 16px; font-family: var(--gyl-font-mono); }
.gyl-brand-kymark .b { font-weight: 700; letter-spacing: -.01em; font-style: italic; }
.gyl-brand-groundwidgets span:first-child { font-weight: 300; opacity: .8; margin-right: 1px; }
.gyl-brand-bro .b { font-weight: 600; letter-spacing: .02em; font-size: 17px; }
.gyl-brand-customapi .mono { color: var(--gyl-gold); opacity: .85; }

@media (max-width: 600px) {
	.gyl-logo-strip__row { gap: 14px 24px; }
	.gyl-logo-strip__item { font-size: 16px; }
	.gyl-logo-strip__item .mono { font-size: 12px; }
	.gyl-brand-hudson .b { font-size: 14px; }
}

/* Light theme — keep the logo strip on a soft cream card so brand marks pop */
body.gyl-theme-light .gyl-logo-strip {
	background: #F5F1E8;
	border-block-color: rgba(0,0,0,.06);
}
body.gyl-theme-light .gyl-logo-strip__lead { color: #5C5852; }
body.gyl-theme-light .gyl-logo-strip__item { color: #1A1A1A; opacity: .55; }
body.gyl-theme-light .gyl-logo-strip__item:hover { color: var(--gyl-gold); opacity: 1; }
body.gyl-theme-light .gyl-brand-customapi .mono { color: #8a6d1a; }

/* ---- pillars (home) ------------------------------------------------------ */
.gyl-pillars__grid { gap: 18px; }
.gyl-pillar {
	position: relative;
	background: linear-gradient(180deg, var(--gyl-graphite), var(--gyl-charcoal));
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	padding: 28px;
	transition: border-color .25s ease, transform .25s ease, box-shadow .3s ease;
}
.gyl-pillar:hover { border-color: var(--gyl-border-strong); transform: translateY(-2px); box-shadow: var(--gyl-shadow-glow); }
.gyl-pillar__num {
	display:inline-block; font-family: var(--gyl-font-mono); font-size: 12px;
	letter-spacing: .2em; color: var(--gyl-gold); margin-bottom: 14px;
}
.gyl-pillar h3 { font-family: var(--gyl-font-display); font-size: 24px; margin: 0 0 8px; color: var(--gyl-ivory); }
.gyl-pillar p { color: var(--gyl-muted); margin: 0 0 16px; }
.gyl-pillar--cta {
	background: linear-gradient(180deg, rgba(212,175,55,.12), rgba(212,175,55,.04));
	border-color: var(--gyl-border-strong);
}

/* ---- stats --------------------------------------------------------------- */
.gyl-stats__grid {
	display:grid; gap: 18px;
	grid-template-columns: repeat( auto-fit, minmax(220px, 1fr) );
}
.gyl-stat {
	display:flex; flex-direction:column; gap: 6px;
	padding: 22px;
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	background: var(--gyl-graphite);
}
.gyl-stat__num {
	font-family: var(--gyl-font-display);
	font-size: clamp(34px, 4vw, 48px);
	color: var(--gyl-gold);
	letter-spacing:-.02em;
}
.gyl-stat__label { color: var(--gyl-muted); font-size: 14px; }

/* ---- process ------------------------------------------------------------- */
.gyl-process__list {
	list-style: none; padding:0; margin: 0 0 28px;
	display:grid; gap:14px;
}
.gyl-process__list li {
	padding: 18px 22px;
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	background: var(--gyl-graphite);
	color: var(--gyl-ivory);
}
.gyl-process__list strong { color: var(--gyl-gold); margin-right: 4px; }

/* ---- portfolio strip ----------------------------------------------------- */
.gyl-grid { display: grid; gap: 22px; }
.gyl-grid--3 { grid-template-columns: 1fr; }
.gyl-grid--4 { grid-template-columns: 1fr; }
@media (min-width: 700px) {
	.gyl-grid--3 { grid-template-columns: repeat(2, 1fr); }
	.gyl-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.gyl-grid--3 { grid-template-columns: repeat(3, 1fr); }
	.gyl-grid--4 { grid-template-columns: repeat(4, 1fr); }
}

.gyl-pf-card {
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	overflow: hidden;
	background: var(--gyl-graphite);
	transition: border-color .25s ease, transform .25s ease, box-shadow .3s ease;
}
.gyl-pf-card:hover { border-color: var(--gyl-border-strong); transform: translateY(-2px); box-shadow: var(--gyl-shadow-glow); }
.gyl-pf-card__media {
	display:block; position:relative; aspect-ratio: 16/10;
	background: linear-gradient(135deg, var(--gyl-charcoal), var(--gyl-graphite));
	overflow:hidden;
}
.gyl-pf-card__media img { width:100%; height:100%; object-fit: cover; }
.gyl-pf-card__placeholder {
	position:absolute; inset:0; display:grid; place-items:center;
	font-family: var(--gyl-font-display); font-size: 64px; color: var(--gyl-gold); letter-spacing:-.02em;
	background: radial-gradient(ellipse at center, rgba(212,175,55,.18), transparent 70%);
}
.gyl-pf-card__chip {
	position:absolute; top:12px; left:12px;
	font-family: var(--gyl-font-mono);
	font-size: 11px; letter-spacing:.2em; text-transform: uppercase;
	color: var(--gyl-black); background: var(--gyl-gold);
	padding: 4px 10px; border-radius: 999px;
}
.gyl-pf-card__body { padding: 18px 20px 22px; }
.gyl-pf-card__title { font-family: var(--gyl-font-display); font-size: 20px; margin:0 0 6px; }
.gyl-pf-card__title a { color: var(--gyl-ivory); }
.gyl-pf-card__title a:hover { color: var(--gyl-gold); text-decoration:none; }
.gyl-pf-card__meta { color: var(--gyl-muted); font-size: 13px; margin: 0 0 8px; font-family: var(--gyl-font-mono); letter-spacing: .04em; }
.gyl-pf-card__excerpt { color: var(--gyl-muted); margin: 0 0 12px; }

/* ---- generic cards ------------------------------------------------------- */
.gyl-card {
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	overflow: hidden;
	background: var(--gyl-graphite);
}
.gyl-card__media { display:block; aspect-ratio: 16/10; overflow:hidden; }
.gyl-card__media img { width:100%; height:100%; object-fit: cover; }
.gyl-card__body { padding: 18px 20px 22px; }
.gyl-card__title { font-family: var(--gyl-font-display); font-size: 20px; margin:0 0 6px; }
.gyl-card__title a { color: var(--gyl-ivory); }
.gyl-card__title a:hover { color: var(--gyl-gold); text-decoration:none; }
.gyl-card__excerpt { color: var(--gyl-muted); margin: 0 0 10px; }
.gyl-card--quiet { background: transparent; }
.gyl-card--quiet h3 { color: var(--gyl-gold); margin-top: 0; }

/* ---- locations ----------------------------------------------------------- */
.gyl-loc-card {
	display:flex; flex-direction:column; gap:6px;
	padding: 22px;
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	background: linear-gradient(180deg, var(--gyl-graphite), var(--gyl-charcoal));
	color: var(--gyl-ivory);
	transition: border-color .25s ease, transform .25s ease, box-shadow .3s ease;
}
.gyl-loc-card:hover { border-color: var(--gyl-border-strong); transform: translateY(-2px); box-shadow: var(--gyl-shadow-glow); text-decoration:none; color: var(--gyl-ivory); }
.gyl-loc-card__flag { font-family: var(--gyl-font-mono); color: var(--gyl-gold); font-size: 13px; letter-spacing:.2em; }
.gyl-loc-card__name { font-family: var(--gyl-font-display); font-size: 22px; }
.gyl-loc-card__hint { color: var(--gyl-muted); font-size: 13px; }

/* ---- location blocks (long pages) --------------------------------------- */
.gyl-location-block { padding: 28px 0; border-bottom:1px solid var(--gyl-border); }
.gyl-chip-list { display:flex; flex-wrap:wrap; gap:8px; padding:0; margin: 12px 0 0; list-style:none; }
.gyl-chip-list li {
	padding: 8px 14px;
	border:1px solid var(--gyl-border);
	border-radius: 999px;
	background: rgba(255,255,255,.02);
	font-size: 14px;
	color: var(--gyl-ivory);
}
.gyl-chip-list--gold li { border-color: var(--gyl-border-strong); }
.gyl-chip-list--gold li strong { color: var(--gyl-gold); font-family: var(--gyl-font-mono); margin-right: 6px; }
.gyl-bullet-list { padding-left: 18px; color: var(--gyl-ivory); }
.gyl-bullet-list li { margin-bottom: 8px; }

/* ---- prose --------------------------------------------------------------- */
.gyl-prose { max-width: 760px; margin-inline: auto; }
.gyl-prose h2, .gyl-prose h3, .gyl-prose h4 { font-family: var(--gyl-font-display); color: var(--gyl-ivory); margin-top: 1.6em; }
.gyl-prose h2 { font-size: clamp(24px, 3vw, 32px); }
.gyl-prose h3 { font-size: clamp(20px, 2vw, 24px); }
.gyl-prose p, .gyl-prose ul, .gyl-prose ol { color: var(--gyl-ivory); }
.gyl-prose ul, .gyl-prose ol { padding-left: 22px; }
.gyl-prose li { margin-bottom: 8px; }
.gyl-prose a { color: var(--gyl-gold); border-bottom: 1px solid var(--gyl-border-strong); }
.gyl-prose a:hover { color: var(--gyl-gold-soft); border-color: var(--gyl-gold-soft); text-decoration: none; }
.gyl-prose blockquote {
	border-left: 3px solid var(--gyl-gold);
	padding: 8px 0 8px 18px;
	color: var(--gyl-ivory);
	font-style: italic;
	margin: 24px 0;
}
.gyl-prose code { font-family: var(--gyl-font-mono); background: var(--gyl-charcoal); padding: 2px 6px; border-radius: 6px; font-size: .92em; }
.gyl-prose pre { background: var(--gyl-charcoal); padding: 16px; border-radius: var(--gyl-radius-sm); overflow:auto; }
.gyl-prose img { border-radius: var(--gyl-radius-sm); margin: 18px 0; }
.gyl-feature-img { margin: 0 0 28px; }
.gyl-feature-img img { border-radius: var(--gyl-radius); }
.gyl-page-head { max-width: 64ch; margin: 0 0 32px; }

/* ---- breadcrumbs --------------------------------------------------------- */
.gyl-breadcrumbs { padding: 18px 0; border-bottom:1px solid var(--gyl-border); }
.gyl-breadcrumbs__list { display:flex; flex-wrap:wrap; gap:6px; padding:0; margin:0; list-style:none; font-size: 13px; }
.gyl-breadcrumbs__list a { color: var(--gyl-muted); }
.gyl-breadcrumbs__list a:hover { color: var(--gyl-gold); text-decoration: none; }
.gyl-breadcrumbs__sep { color: var(--gyl-muted); margin: 0 4px; }
[aria-current="page"] { color: var(--gyl-ivory); }

/* ---- FAQ ---------------------------------------------------------------- */
.gyl-faq__list { display:grid; gap:10px; }
.gyl-faq__item {
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius-sm);
	background: var(--gyl-graphite);
	overflow: hidden;
}
.gyl-faq__q {
	cursor: pointer;
	padding: 18px 20px;
	font-weight: 600;
	display:flex; align-items:center; justify-content:space-between;
	gap: 16px;
	color: var(--gyl-ivory);
	list-style: none;
}
.gyl-faq__q::-webkit-details-marker { display: none; }
.gyl-faq__icon { color: var(--gyl-gold); font-size: 22px; line-height: 1; transition: transform .2s ease; }
.gyl-faq__item[open] .gyl-faq__icon { transform: rotate(45deg); }
.gyl-faq__a { padding: 0 20px 22px; color: var(--gyl-muted); }
.gyl-faq__a p { margin: 0 0 12px; }

/* ---- CTA band ------------------------------------------------------------ */
.gyl-cta-band {
	position: relative; overflow: hidden;
	padding: clamp(56px, 7vw, 96px) 0;
	background: linear-gradient(180deg, var(--gyl-graphite), var(--gyl-black));
	border-block:1px solid var(--gyl-border);
}
.gyl-cta-band__glow {
	position:absolute; right:-20%; top:-30%;
	width:60vw; aspect-ratio:1;
	background: radial-gradient(closest-side, rgba(212,175,55,.18), transparent 70%);
	filter: blur(20px);
	pointer-events:none;
}
.gyl-cta-band__inner {
	position: relative; z-index:1;
	display: grid; gap: 20px;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 980px) {
	.gyl-cta-band__inner { grid-template-columns: 1.4fr 1fr; }
}
.gyl-cta-band .gyl-h1 { margin: 8px 0 8px; }

/* ---- portfolio strip / related -------------------------------------- */
.gyl-related { padding-top: 28px; }
.gyl-related__list { display:flex; flex-wrap:wrap; gap:10px; padding:0; margin: 12px 0 0; list-style:none; }
.gyl-related__list a {
	display:inline-block; padding: 10px 16px;
	border:1px solid var(--gyl-border); border-radius: 999px;
	color: var(--gyl-ivory); background: var(--gyl-graphite); font-size: 14px;
}
.gyl-related__list a:hover { color: var(--gyl-gold); border-color: var(--gyl-border-strong); text-decoration: none; }

/* ---- search results ------------------------------------------------------ */
.gyl-search-results { list-style: none; padding:0; margin:0; display:grid; gap: 18px; }
.gyl-search-results li { padding: 18px; border:1px solid var(--gyl-border); border-radius: var(--gyl-radius-sm); background: var(--gyl-graphite); }
.gyl-search-results li a { color: var(--gyl-ivory); display:block; margin-bottom: 6px; }
.gyl-search-results li p { color: var(--gyl-muted); margin: 0; }

/* ---- pagination ---------------------------------------------------------- */
.gyl-pagination { margin-top: 36px; display:flex; justify-content:center; }
.gyl-pagination .nav-links { display:flex; gap:8px; flex-wrap: wrap; }
.gyl-pagination a, .gyl-pagination span {
	display:inline-grid; place-items:center;
	min-width: 38px; height: 38px;
	border:1px solid var(--gyl-border);
	border-radius: 999px;
	color: var(--gyl-ivory);
	padding: 0 12px;
	background: var(--gyl-graphite);
}
.gyl-pagination .current { background: var(--gyl-gold); color: var(--gyl-black); border-color: var(--gyl-gold); }

/* ---- footer -------------------------------------------------------------- */
.gyl-footer { padding: 64px 0 110px; background: var(--gyl-graphite); border-top:1px solid var(--gyl-border); }
.gyl-footer__grid {
	display:grid; gap: 36px;
	grid-template-columns: 1fr;
}
@media (min-width: 760px) { .gyl-footer__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .gyl-footer__grid { grid-template-columns: 1.6fr repeat(4, 1fr); } }
.gyl-footer__about p { color: var(--gyl-muted); max-width: 40ch; }
.gyl-footer__col h4 {
	font-family: var(--gyl-font-mono);
	font-size: 12px; letter-spacing:.2em;
	color: var(--gyl-gold); text-transform: uppercase;
	margin: 0 0 14px;
}
.gyl-footer__list { list-style: none; padding:0; margin:0; display:grid; gap:8px; }
.gyl-footer__list a { color: var(--gyl-ivory); font-size: 14px; }
.gyl-footer__list a:hover { color: var(--gyl-gold); text-decoration:none; }
.gyl-footer__bottom { display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-top: 36px; padding-top: 18px; border-top:1px solid var(--gyl-border); color: var(--gyl-muted); font-size: 13px; }
.gyl-footer__bottom a { color: var(--gyl-muted); }

/* ---- mobile bottom CTA bar ---------------------------------------------- */
.gyl-mobile-bar {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
	display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
	padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px));
	background: rgba(6,6,6,.88);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-top: 1px solid var(--gyl-border);
}
.gyl-mobile-bar__btn {
	text-align:center; padding: 12px 14px;
	border-radius: 999px;
	font-weight: 600; font-size: 14px;
	color: var(--gyl-ivory);
	background: rgba(212,175,55,.06);
	border: 1px solid var(--gyl-border-strong);
}
.gyl-mobile-bar__btn--primary { background: var(--gyl-gold); color: var(--gyl-black); border-color: var(--gyl-gold); }
.gyl-mobile-bar__btn:hover { text-decoration: none; }
@media (min-width: 1024px) { .gyl-mobile-bar { display:none; } .gyl-footer { padding-bottom: 64px; } }

/* ---- 404 ----------------------------------------------------------------- */
.gyl-404 { text-align:left; }
.gyl-404 .gyl-display { margin-bottom: 12px; }

/* ---- search form -------------------------------------------------------- */
.gyl-searchform { display:flex; gap:8px; max-width: 480px; }
.gyl-searchform input[type="search"] {
	flex:1; padding: 12px 14px;
	border-radius: 999px;
	border:1px solid var(--gyl-border-strong);
	background: var(--gyl-graphite);
	color: var(--gyl-ivory);
	font-family: inherit;
}

/* ---- audit embed -------------------------------------------------------- */
.gyl-audit-embed__inner {
	max-width: 920px; margin-inline:auto;
	padding: 28px;
	background: var(--gyl-graphite);
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius-lg);
}
.gyl-audit-embed__fallback { text-align:center; }
.gyl-audit-embed__fallback code { font-family: var(--gyl-font-mono); color: var(--gyl-gold); }

/* ---- calendly ----------------------------------------------------------- */
.gyl-calendly-embed {
	min-height: 720px;
	border:1px solid var(--gyl-border);
	border-radius: var(--gyl-radius-lg);
	overflow: hidden;
	background: var(--gyl-graphite);
}

/* ---- reveal animations -------------------------------------------------- */
[data-gyl-reveal] {
	opacity: 0;
	transform: translateY(14px);
	transition: opacity .8s ease, transform .8s ease;
}
[data-gyl-reveal].is-revealed {
	opacity: 1; transform: none;
}
@media (prefers-reduced-motion: reduce) {
	[data-gyl-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   SMART HERO — dark luxe gradient + smart search bar
   ============================================================ */
.gyl-smart-hero {
	position: relative;
	overflow: hidden;
	background: var(--gyl-black);
	padding: clamp(28px, 4vw, 56px) 0 clamp(40px, 5vw, 72px);
	display: flex;
	align-items: flex-start;
}
.gyl-smart-hero__inner {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1080px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

/* Gradient glow rows (skewed/blurred bars — gold version of hero-1.tsx) */
.gyl-smart-hero__glows { position: absolute; inset: 0; pointer-events: none; z-index: 1; }
.gyl-smart-hero__glow-row {
	position: absolute;
	display: flex;
	gap: 9rem;
	transform: rotate(-20deg) skew(-40deg);
	filter: blur(64px);
	opacity: .55;
}
.gyl-smart-hero__glow-row--1 { top: -36rem; right: -28rem; }
.gyl-smart-hero__glow-row--2 { top: -46rem; right: -46rem; opacity: .42; }
.gyl-smart-hero__glow-row--3 { top: -56rem; right: -56rem; opacity: .32; }
.gyl-smart-hero__glow-row span {
	display: block;
	width: 9rem;
	height: 22rem;
	background: linear-gradient(90deg, var(--gyl-ivory) 0%, var(--gyl-gold) 60%, transparent 100%);
	border-radius: 4px;
}
.gyl-smart-hero__glow-row--3 span { height: 30rem; }

/* Eyebrow — small, mono, gold. Sits above the H1. */
.gyl-smart-hero__eyebrow {
	display: inline-block;
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--gyl-gold);
	margin-bottom: 14px;
}

/* Headline — tuned to wrap to ~2 balanced lines on desktop, 3 max on mobile.
   65 chars / 2 lines ≈ 33 chars per line, so max-width needs to allow ~40ch. */
.gyl-smart-hero__title {
	font-family: var(--gyl-font-display);
	font-weight: 600;
	font-size: clamp(22px, 3.2vw, 38px);
	line-height: 1.08;
	letter-spacing: -.02em;
	color: var(--gyl-ivory);
	margin: 0 0 14px;
	max-width: 42ch;
	margin-inline: auto;
	text-wrap: balance;
}
@media (max-width: 600px) {
	.gyl-smart-hero__title {
		font-size: clamp(22px, 6.2vw, 28px);
		max-width: 26ch;
	}
}
.gyl-smart-hero__lead {
	color: var(--gyl-muted);
	font-size: clamp(14px, 1.4vw, 17px);
	line-height: 1.55;
	margin: 0 auto 22px;
	max-width: 56ch;
	text-wrap: pretty;
}

/* Smart search */
.gyl-smart-search {
	position: relative;
	width: 100%;
	max-width: 640px;
	margin-inline: auto;
	text-align: left;
}
.gyl-smart-search__bar {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	background: var(--gyl-graphite);
	border: 1px solid var(--gyl-border);
	border-radius: 999px;
	transition: border-color .2s ease, box-shadow .2s ease;
}
.gyl-smart-search__bar:focus-within {
	border-color: var(--gyl-gold);
	box-shadow: 0 0 0 3px rgba(212,175,55,.18);
}
.gyl-smart-search__icon { color: var(--gyl-muted); flex-shrink: 0; }
.gyl-smart-search__bar:focus-within .gyl-smart-search__icon { color: var(--gyl-gold); }
.gyl-smart-search__input {
	flex: 1;
	min-width: 0;
	background: transparent;
	border: 0;
	outline: 0;
	color: var(--gyl-ivory);
	font-family: inherit;
	font-size: 15px;
	padding: 4px 0;
}
.gyl-smart-search__input::placeholder { color: rgba(184,176,160,.55); }
.gyl-smart-search__mode {
	flex-shrink: 0;
	font-family: var(--gyl-font-mono);
	font-size: 10px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--gyl-gold);
	padding: 4px 8px;
	border: 1px solid var(--gyl-border);
	border-radius: 999px;
	background: rgba(212,175,55,.06);
}
.gyl-smart-search__mode:empty { display: none; }
.gyl-smart-search__clear {
	flex-shrink: 0;
	background: transparent;
	border: 0;
	color: var(--gyl-muted);
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	padding: 0 4px;
}
.gyl-smart-search__clear:hover { color: var(--gyl-ivory); }

.gyl-smart-search__hint {
	margin-top: 10px;
	font-size: 12px;
	color: var(--gyl-muted);
	text-align: center;
}
.gyl-smart-search__hint code {
	font-family: var(--gyl-font-mono);
	background: var(--gyl-charcoal);
	padding: 2px 6px;
	border-radius: 5px;
	color: var(--gyl-gold-soft);
}

/* Force [hidden] elements stay hidden — overrides flex/grid display:none clashes */
.gyl-smart-search [hidden] { display: none !important; }

/* URL mode quick actions */
.gyl-smart-search__url-actions {
	margin-top: 14px;
	padding: 18px 16px;
	background: var(--gyl-graphite);
	border: 1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	display: flex;
	flex-direction: column;
	gap: 14px;
	align-items: center;
	text-align: center;
}
.gyl-smart-search__url-label {
	font-size: 14px;
	color: var(--gyl-muted);
	text-align: center;
}
.gyl-smart-search__url-label strong { color: var(--gyl-ivory); }
.gyl-smart-search__url-cta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
}

/* Autocomplete dropdown */
.gyl-smart-search__dropdown {
	position: absolute;
	left: 0; right: 0;
	margin-top: 10px;
	background: var(--gyl-graphite);
	border: 1px solid var(--gyl-border-strong);
	border-radius: var(--gyl-radius);
	box-shadow: 0 30px 60px rgba(0,0,0,.5);
	overflow: hidden;
	z-index: 5;
	max-height: 360px;
	overflow-y: auto;
}
.gyl-smart-search__dropdown-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	cursor: pointer;
	border-bottom: 1px solid var(--gyl-border);
	transition: background .12s ease;
}
.gyl-smart-search__dropdown-item:last-child { border-bottom: 0; }
.gyl-smart-search__dropdown-item.is-active,
.gyl-smart-search__dropdown-item:hover {
	background: rgba(212,175,55,.08);
}
.gyl-smart-search__dropdown-item-pin {
	display: inline-grid; place-items: center;
	width: 32px; height: 32px;
	background: var(--gyl-charcoal);
	border-radius: 8px;
	color: var(--gyl-gold);
	flex-shrink: 0;
	font-size: 14px;
}
.gyl-smart-search__dropdown-item-text { flex: 1; min-width: 0; }
.gyl-smart-search__dropdown-item-main {
	font-size: 14px;
	color: var(--gyl-ivory);
	font-weight: 500;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.gyl-smart-search__dropdown-item-sec {
	font-size: 12px;
	color: var(--gyl-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.gyl-smart-search__dropdown-empty,
.gyl-smart-search__dropdown-loading {
	padding: 14px 16px;
	font-size: 13px;
	color: var(--gyl-muted);
	text-align: center;
}

/* GMB business card */
.gyl-smart-search__card {
	margin-top: 14px;
	padding: 18px;
	background: linear-gradient(180deg, rgba(212,175,55,.06), rgba(17,17,17,.95));
	border: 1px solid var(--gyl-border-strong);
	border-radius: var(--gyl-radius-lg);
	display: flex;
	flex-direction: column;
	gap: 16px;
	text-align: left;
}
.gyl-biz-card__main {
	display: flex;
	gap: 14px;
	align-items: center;
}
.gyl-biz-card__photo {
	width: 56px; height: 56px;
	border-radius: 12px;
	background: var(--gyl-charcoal);
	overflow: hidden;
	flex-shrink: 0;
	position: relative;
	display: grid;
	place-items: center;
}
.gyl-biz-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.gyl-biz-card__photo-fallback {
	font-family: var(--gyl-font-display);
	font-size: 13px;
	color: var(--gyl-gold);
	letter-spacing: .04em;
}
.gyl-biz-card__body { flex: 1; min-width: 0; }
.gyl-biz-card__name {
	font-family: var(--gyl-font-display);
	font-size: 18px;
	color: var(--gyl-ivory);
	margin: 0 0 4px;
	letter-spacing: -.005em;
}
.gyl-biz-card__meta {
	font-size: 12px;
	color: var(--gyl-muted);
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 4px;
}
.gyl-biz-card__meta .gyl-biz-rating { color: var(--gyl-gold); font-weight: 600; }
.gyl-biz-card__site {
	font-size: 12px;
	color: var(--gyl-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.gyl-biz-card__site a { color: var(--gyl-gold); text-decoration: none; }
.gyl-biz-card__site a:hover { color: var(--gyl-gold-soft); text-decoration: underline; }
.gyl-biz-card__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: flex-start;
}

/* Capture (email + phone) */
.gyl-smart-search__capture {
	margin-top: 14px;
	padding: 16px;
	background: var(--gyl-graphite);
	border: 1px solid var(--gyl-border-strong);
	border-radius: var(--gyl-radius);
	text-align: left;
	position: relative;
}
.gyl-smart-search__capture-row {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 8px;
	align-items: center;
}
@media (max-width: 600px) {
	.gyl-smart-search__capture-row { grid-template-columns: 1fr; }
}
.gyl-smart-search__capture-row input {
	padding: 12px 14px;
	background: var(--gyl-black);
	border: 1px solid var(--gyl-border);
	border-radius: 10px;
	color: var(--gyl-ivory);
	font-family: inherit;
	font-size: 14px;
	width: 100%;
}
.gyl-smart-search__capture-row input::placeholder { color: rgba(184,176,160,.55); }
.gyl-smart-search__capture-row input:focus-visible { outline: 0; border-color: var(--gyl-gold); box-shadow: 0 0 0 3px rgba(212,175,55,.18); }
.gyl-smart-search__capture-hint {
	margin: 10px 0 0;
	font-size: 11px;
	color: var(--gyl-muted);
	text-align: center;
}
.gyl-smart-search__capture-error {
	margin: 10px 0 0;
	padding: 10px 12px;
	background: rgba(255,99,99,.08);
	border: 1px solid rgba(255,99,99,.4);
	border-radius: 8px;
	font-size: 13px;
	color: #ffd0d0;
}

/* Success state */
.gyl-smart-search__success {
	margin-top: 14px;
	padding: 24px;
	background: var(--gyl-graphite);
	border: 1px solid var(--gyl-border-strong);
	border-radius: var(--gyl-radius-lg);
	text-align: center;
}
.gyl-smart-search__success-icon {
	display: inline-grid; place-items: center;
	width: 48px; height: 48px;
	border-radius: 50%;
	background: var(--gyl-gold);
	color: var(--gyl-black);
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 10px;
}
.gyl-smart-search__success h3 {
	font-family: var(--gyl-font-display);
	font-size: 22px;
	color: var(--gyl-ivory);
	margin: 0 0 6px;
}
.gyl-smart-search__success p { color: var(--gyl-muted); margin: 0 0 12px; font-size: 14px; }

/* Trust strip — sits IMMEDIATELY under the search bar so it boosts conversion.
   Mobile: stacks. Desktop: single row separated by gold dots. */
.gyl-smart-hero__trust {
	margin: 18px auto 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	column-gap: 18px;
	row-gap: 6px;
	justify-content: center;
	align-items: center;
	font-size: 12px;
	color: var(--gyl-muted);
	font-family: var(--gyl-font-mono);
	letter-spacing: .04em;
	max-width: 700px;
}
.gyl-smart-hero__trust li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
	position: relative;
}
.gyl-smart-hero__trust li + li::before {
	content: "";
	position: absolute;
	left: -10px;
	top: 50%;
	width: 3px; height: 3px;
	border-radius: 50%;
	background: var(--gyl-gold);
	transform: translateY(-50%);
}
.gyl-smart-hero__trust strong { color: var(--gyl-ivory); font-weight: 700; }

/* Suggestion pills — compact, secondary nav style */
.gyl-smart-hero__pills {
	margin-top: 24px;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: center;
	align-items: center;
}
.gyl-smart-hero__pills-label {
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--gyl-muted);
	margin-right: 6px;
	width: 100%;
	text-align: center;
}
@media (min-width: 600px) {
	.gyl-smart-hero__pills-label { width: auto; }
}
.gyl-smart-hero__pill {
	background: transparent;
	border: 1px solid var(--gyl-border);
	color: var(--gyl-ivory);
	padding: 6px 12px;
	border-radius: 999px;
	font-size: 12.5px;
	font-weight: 500;
	cursor: pointer;
	font-family: inherit;
	text-decoration: none;
	transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.gyl-smart-hero__pill:hover {
	background: rgba(212,175,55,.08);
	border-color: var(--gyl-gold);
	color: var(--gyl-gold);
	text-decoration: none;
}
.gyl-smart-hero__pill:focus-visible {
	outline: 2px solid var(--gyl-gold);
	outline-offset: 3px;
}

/* ---- hero audit launcher ------------------------------------------------- */
.gyl-audit-launcher {
	margin-top: 32px;
	max-width: 720px;
	background: linear-gradient(180deg, rgba(17,17,17,.92), rgba(26,26,26,.92));
	border: 1px solid var(--gyl-border-strong);
	border-radius: var(--gyl-radius-lg);
	padding: 22px;
	box-shadow: var(--gyl-shadow-card);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.gyl-audit-launcher__head { margin-bottom: 16px; }
.gyl-audit-launcher__title {
	font-family: var(--gyl-font-display);
	font-size: clamp(20px, 2.4vw, 26px);
	margin: 0 0 6px;
	color: var(--gyl-ivory);
	letter-spacing: -.01em;
}
.gyl-audit-launcher__sub {
	color: var(--gyl-muted);
	margin: 0;
	font-size: 14px;
}

.gyl-audit-launcher__tabs {
	display: flex;
	gap: 8px;
	margin-bottom: 16px;
	padding: 4px;
	background: var(--gyl-charcoal);
	border-radius: 999px;
	border: 1px solid var(--gyl-border);
	width: fit-content;
}
.gyl-audit-launcher__tab {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 8px 14px;
	background: transparent;
	border: 0;
	color: var(--gyl-muted);
	font-family: inherit;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .02em;
	border-radius: 999px;
	cursor: pointer;
	transition: background .2s ease, color .2s ease;
}
.gyl-audit-launcher__tab.is-active {
	background: var(--gyl-gold);
	color: var(--gyl-black);
}
.gyl-audit-launcher__tab-icon { font-size: 14px; }

.gyl-audit-launcher__form {
	display: none;
	position: relative;
}
.gyl-audit-launcher__form.is-active { display: block; }

.gyl-audit-launcher__row {
	display: grid;
	gap: 10px;
	grid-template-columns: 1fr;
	margin-bottom: 10px;
}
@media (min-width: 600px) {
	.gyl-audit-launcher__row { grid-template-columns: 1fr 1fr; }
	.gyl-audit-launcher__row--main { grid-template-columns: 1fr; }
}
@media (min-width: 600px) {
	.gyl-audit-launcher__form[data-mode="gmb"] .gyl-audit-launcher__row--main {
		grid-template-columns: 2fr 1fr;
	}
}

.gyl-audit-launcher__field { display: flex; flex-direction: column; gap: 4px; }
.gyl-audit-launcher__label {
	font-family: var(--gyl-font-mono);
	font-size: 11px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--gyl-muted);
}
.gyl-audit-launcher__field input {
	padding: 14px 16px;
	background: var(--gyl-black);
	color: var(--gyl-ivory);
	border: 1px solid var(--gyl-border);
	border-radius: 12px;
	font-family: inherit;
	font-size: 15px;
	transition: border-color .2s ease, box-shadow .2s ease;
	width: 100%;
}
.gyl-audit-launcher__field input::placeholder { color: rgba(184,176,160,.55); }
.gyl-audit-launcher__field input:focus-visible {
	outline: none;
	border-color: var(--gyl-gold);
	box-shadow: 0 0 0 3px rgba(212,175,55,.18);
}

.gyl-audit-launcher__cta {
	width: 100%;
	margin-top: 4px;
	font-size: 16px;
	padding: 16px 22px;
}
.gyl-audit-launcher__cta:disabled { opacity: .65; cursor: wait; }

.gyl-audit-launcher__fineprint {
	margin: 10px 0 0;
	font-size: 12px;
	color: var(--gyl-muted);
	text-align: center;
}

.gyl-audit-launcher__status {
	margin-top: 14px;
	padding: 12px 14px;
	border-radius: 10px;
	border: 1px solid var(--gyl-border);
	background: var(--gyl-charcoal);
	color: var(--gyl-ivory);
	font-size: 14px;
}
.gyl-audit-launcher__status.is-error {
	border-color: rgba(255,99,99,.5);
	background: rgba(255,99,99,.08);
	color: #ffd0d0;
}

.gyl-audit-launcher__success {
	text-align: center;
	padding: 20px 12px;
}
.gyl-audit-launcher__success-icon {
	display: inline-grid; place-items: center;
	width: 56px; height: 56px;
	border-radius: 50%;
	background: var(--gyl-gold);
	color: var(--gyl-black);
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 12px;
}
.gyl-audit-launcher__success h3 {
	font-family: var(--gyl-font-display);
	font-size: 24px;
	margin: 0 0 8px;
	color: var(--gyl-ivory);
}
.gyl-audit-launcher__success p { color: var(--gyl-muted); margin: 0 0 12px; }
.gyl-audit-launcher__success a { margin-top: 8px; }

/* ---- tools spotlight band ------------------------------------------------ */
.gyl-tools-band {
	background:
		radial-gradient(1000px 500px at 90% -20%, rgba(212,175,55,.10), transparent 55%),
		linear-gradient(180deg, var(--gyl-black), var(--gyl-graphite));
	border-block: 1px solid var(--gyl-border);
}
.gyl-tools-band--home { padding-top: clamp(56px, 8vw, 120px); }
.gyl-tools-band__more { margin-top: 24px; }

/* tool card (theme-side; the plugin's hub has its own card style) */
.gyl-tool-card {
	display: flex; flex-direction: column; gap: 8px;
	padding: 24px;
	background: linear-gradient(180deg, var(--gyl-graphite), var(--gyl-charcoal));
	border: 1px solid var(--gyl-border);
	border-radius: var(--gyl-radius);
	color: var(--gyl-ivory);
	text-decoration: none;
	transition: border-color .25s ease, transform .25s ease, box-shadow .3s ease;
	position: relative;
}
.gyl-tool-card:hover {
	border-color: var(--gyl-border-strong);
	transform: translateY(-2px);
	box-shadow: var(--gyl-shadow-glow);
	color: var(--gyl-ivory);
	text-decoration: none;
}
.gyl-tool-card__icon {
	display: inline-grid; place-items: center;
	width: 44px; height: 44px;
	border-radius: 12px;
	background: rgba(212,175,55,.10);
	border: 1px solid var(--gyl-border-strong);
	color: var(--gyl-gold);
	margin-bottom: 10px;
	transition: background .2s ease, transform .2s ease;
}
.gyl-tool-card__icon svg { display: block; }
.gyl-tool-card:hover .gyl-tool-card__icon {
	background: rgba(212,175,55,.18);
	transform: scale(1.04) rotate(-1.5deg);
}

/* Light theme: keep the cream tint but stronger gold border */
body.gyl-theme-light .gyl-tool-card__icon {
	background: rgba(212,175,55,.14);
	border-color: rgba(212,175,55,.45);
}
.gyl-tool-card__title {
	font-family: var(--gyl-font-display);
	font-size: 22px;
	margin: 0;
	color: var(--gyl-ivory);
	letter-spacing: -.01em;
}
.gyl-tool-card__desc { color: var(--gyl-muted); margin: 0 0 8px; }

/* ============================================================
   LIGHT THEME PREVIEW — toggled via ?theme=light URL parameter.
   Flips the variable system + overrides hardcoded dark values.
   ============================================================ */
body.gyl-theme-light {
	--gyl-black:    #FAF8F2;   /* was main bg */
	--gyl-graphite: #FFFFFF;   /* cards */
	--gyl-charcoal: #F0EBE0;   /* inputs */
	--gyl-ivory:    #1A1A1A;   /* was main text */
	--gyl-muted:    #5C5852;
	--gyl-border:   rgba(0,0,0,.10);
	--gyl-border-strong: rgba(212,175,55,.55);

	background: var(--gyl-black);
	color: var(--gyl-ivory);
}

body.gyl-theme-light a:focus-visible { outline-color: var(--gyl-gold); }

/* Header */
body.gyl-theme-light .gyl-header {
	background: rgba(255,255,255,.92);
	border-bottom-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-header.is-scrolled { background: #FFFFFF; border-bottom-color: var(--gyl-border-strong); }
body.gyl-theme-light .gyl-logo,
body.gyl-theme-light .gyl-logo__word,
body.gyl-theme-light .gyl-nav__link,
body.gyl-theme-light .gyl-search-trigger__label { color: #1A1A1A; }
body.gyl-theme-light .gyl-burger span { background: #1A1A1A; }
body.gyl-theme-light .gyl-search-trigger {
	background: #F5F1E8;
	border-color: rgba(0,0,0,.10);
}
body.gyl-theme-light .gyl-search-trigger__kbd {
	background: #E9E3D6;
	border-color: rgba(0,0,0,.10);
	color: #5C5852;
}

/* Mega menu panels */
body.gyl-theme-light .gyl-mega {
	background: #FFFFFF;
	border-bottom-color: var(--gyl-border);
	box-shadow: 0 30px 60px rgba(0,0,0,.10);
}
body.gyl-theme-light .gyl-mega__list li a { color: #1A1A1A; }
body.gyl-theme-light .gyl-mega__list li a:hover { color: var(--gyl-gold); }

/* Smart hero — DARK on the light page (Apple-style: dark hero + light body).
   Strong dark gradient over the hero image so text stays readable. */
body.gyl-theme-light .gyl-smart-hero {
	background: linear-gradient(180deg, #0F0E0C 0%, #1A1814 100%);
	color: #F7F1E3;
	border-bottom: 1px solid rgba(212,175,55,.15);
}
body.gyl-theme-light .gyl-smart-hero.has-hero-image {
	background:
		linear-gradient(180deg, rgba(6,6,6,.78) 0%, rgba(6,6,6,.84) 50%, rgba(15,14,12,.96) 100%),
		var(--gyl-hero-image, none) center/cover no-repeat,
		#0F0E0C;
}

/* Hero glow rows — keep them showing through but subtle on dark hero */
body.gyl-theme-light .gyl-smart-hero__glow-row { opacity: .3; }
body.gyl-theme-light .gyl-smart-hero__glow-row--3 { opacity: .2; }

body.gyl-theme-light .gyl-smart-hero__eyebrow { color: var(--gyl-gold); }
body.gyl-theme-light .gyl-smart-hero__title { color: #F7F1E3; }
body.gyl-theme-light .gyl-smart-hero__lead { color: #D8D2C2; }

/* Search bar on dark hero — glassy dark with strong gold focus */
body.gyl-theme-light .gyl-smart-search__bar {
	background: rgba(255,255,255,.06);
	border-color: rgba(212,175,55,.20);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
body.gyl-theme-light .gyl-smart-search__bar:focus-within {
	background: rgba(255,255,255,.10);
	border-color: var(--gyl-gold);
	box-shadow: 0 0 0 3px rgba(212,175,55,.20);
}
body.gyl-theme-light .gyl-smart-search__input { color: #F7F1E3; }
body.gyl-theme-light .gyl-smart-search__input::placeholder { color: rgba(247,241,227,.55); }
body.gyl-theme-light .gyl-smart-search__icon { color: var(--gyl-gold); }
body.gyl-theme-light .gyl-smart-search__hint { color: #B8B0A0; }
body.gyl-theme-light .gyl-smart-search__hint code {
	background: rgba(212,175,55,.12);
	color: #F3D58A;
}

/* Pills on dark hero */
body.gyl-theme-light .gyl-smart-hero__pill {
	background: rgba(255,255,255,.04);
	border-color: rgba(247,241,227,.18);
	color: #F7F1E3;
}
body.gyl-theme-light .gyl-smart-hero__pill:hover {
	background: rgba(212,175,55,.12);
	border-color: var(--gyl-gold);
	color: var(--gyl-gold);
}
body.gyl-theme-light .gyl-smart-hero__pills-label { color: #B8B0A0; }

/* Trust strip on dark hero */
body.gyl-theme-light .gyl-smart-hero__trust { color: #B8B0A0; }
body.gyl-theme-light .gyl-smart-hero__trust strong { color: #F7F1E3; }

/* Pillars / cards / sections */
body.gyl-theme-light .gyl-pillar,
body.gyl-theme-light .gyl-stat,
body.gyl-theme-light .gyl-tool-card,
body.gyl-theme-light .gyl-pf-card,
body.gyl-theme-light .gyl-card,
body.gyl-theme-light .gyl-loc-card,
body.gyl-theme-light .gyl-faq__item,
body.gyl-theme-light .gyl-process__list li,
body.gyl-theme-light .gyl-search-results li {
	background: #FFFFFF;
	border-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-pillar h3,
body.gyl-theme-light .gyl-tool-card__title,
body.gyl-theme-light .gyl-pf-card__title a,
body.gyl-theme-light .gyl-card__title a,
body.gyl-theme-light .gyl-loc-card__name,
body.gyl-theme-light .gyl-faq__q { color: #1A1A1A; }
body.gyl-theme-light .gyl-pillar p,
body.gyl-theme-light .gyl-tool-card__desc,
body.gyl-theme-light .gyl-pf-card__excerpt,
body.gyl-theme-light .gyl-card__excerpt,
body.gyl-theme-light .gyl-loc-card__hint,
body.gyl-theme-light .gyl-faq__a,
body.gyl-theme-light .gyl-stat__label { color: #5C5852; }
body.gyl-theme-light .gyl-pillar--cta {
	background: linear-gradient(180deg, rgba(212,175,55,.18), rgba(212,175,55,.06));
	border-color: var(--gyl-border-strong);
}

/* CTA band */
body.gyl-theme-light .gyl-cta-band {
	background: linear-gradient(180deg, #FFFFFF, #F5F1E8);
	border-block-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-cta-band .gyl-h1 { color: #1A1A1A; }

/* Tools spotlight band */
body.gyl-theme-light .gyl-tools-band {
	background: linear-gradient(180deg, #FAF8F2, #F5F1E8);
}

/* Footer + mobile bar */
body.gyl-theme-light .gyl-footer {
	background: #FFFFFF;
	border-top-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-footer__list a { color: #1A1A1A; }
body.gyl-theme-light .gyl-footer__bottom { color: #5C5852; border-top-color: var(--gyl-border); }
body.gyl-theme-light .gyl-mobile-bar {
	background: rgba(255,255,255,.92);
	border-top-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-mobile-bar__btn { color: #1A1A1A; background: rgba(212,175,55,.10); }

/* Logo strip + various sections */
body.gyl-theme-light .gyl-logo-strip {
	background: #FFFFFF;
	border-block-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-logo-strip__row span { color: #1A1A1A; }

/* Breadcrumbs */
body.gyl-theme-light .gyl-breadcrumbs { border-bottom-color: var(--gyl-border); }

/* Prose */
body.gyl-theme-light .gyl-prose,
body.gyl-theme-light .gyl-prose h2,
body.gyl-theme-light .gyl-prose h3,
body.gyl-theme-light .gyl-prose h4,
body.gyl-theme-light .gyl-prose p,
body.gyl-theme-light .gyl-prose ul,
body.gyl-theme-light .gyl-prose ol,
body.gyl-theme-light .gyl-prose li { color: #1A1A1A; }
body.gyl-theme-light .gyl-prose code { background: #F0EBE0; }
body.gyl-theme-light .gyl-prose pre { background: #1A1A1A; color: #F0EBE0; }

/* Hero (page.php standard hero) */
body.gyl-theme-light .gyl-hero {
	background: linear-gradient(180deg, #FAF8F2 0%, #F5F1E8 100%);
}
body.gyl-theme-light .gyl-hero .gyl-display { color: #1A1A1A; }
body.gyl-theme-light .gyl-hero .gyl-lead { color: #5C5852; }
body.gyl-theme-light .gyl-hero__chips li {
	background: #FFFFFF;
	border-color: var(--gyl-border);
	color: #5C5852;
}

/* Mega menu open pillar nav (mobile sheet) */
body.gyl-theme-light .gyl-sheet__panel {
	background: #FFFFFF;
	border-left-color: var(--gyl-border);
}
body.gyl-theme-light .gyl-sheet__summary,
body.gyl-theme-light .gyl-sheet__flat,
body.gyl-theme-light .gyl-sheet__sub a { color: #1A1A1A; }

/* Search palette */
body.gyl-theme-light .gyl-search__panel {
	background: #FFFFFF;
	border-color: var(--gyl-border-strong);
}
body.gyl-theme-light .gyl-search__overlay { background: rgba(26,26,26,.55); }
body.gyl-theme-light .gyl-search__input { color: #1A1A1A; }

/* Tools band cards */
body.gyl-theme-light .gyl-tool-card { background: #FFFFFF; }

/* Buttons stay gold (good on both themes) — only the ghost button needs adjusting */
body.gyl-theme-light .gyl-btn--ghost {
	color: #1A1A1A;
	border-color: rgba(0,0,0,.20);
}
body.gyl-theme-light .gyl-btn--ghost:hover {
	color: var(--gyl-gold);
	border-color: var(--gyl-gold);
	background: rgba(212,175,55,.08);
}

/* ---- inline images injected by the_content filter ----------------------- */
.gyl-inline-img {
	margin: 32px 0;
	border-radius: var(--gyl-radius);
	overflow: hidden;
	border: 1px solid var(--gyl-border);
	background: var(--gyl-graphite);
	box-shadow: 0 30px 60px rgba(0,0,0,.4);
}
.gyl-inline-img img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 480px;
	object-fit: cover;
}

/* ---- homepage hero image (when generated) ------------------------------- */
.gyl-hero--home.has-hero-image {
	background:
		linear-gradient(180deg, rgba(6,6,6,.55) 0%, rgba(6,6,6,.85) 60%, var(--gyl-black) 100%),
		var(--gyl-hero-image, none) center/cover no-repeat,
		var(--gyl-black);
}
.gyl-smart-hero.has-hero-image {
	background:
		linear-gradient(180deg, rgba(6,6,6,.40) 0%, rgba(6,6,6,.78) 70%, var(--gyl-black) 100%),
		var(--gyl-hero-image, none) center/cover no-repeat,
		var(--gyl-black);
}

/* ---- pillar images (homepage 5 services) -------------------------------- */
.gyl-pillar__img {
	display: block;
	margin: -28px -28px 18px;
	height: 160px;
	overflow: hidden;
	border-bottom: 1px solid var(--gyl-border);
	border-radius: var(--gyl-radius) var(--gyl-radius) 0 0;
}
.gyl-pillar__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gyl-pillar { overflow: hidden; }

/* ---- helpers ------------------------------------------------------------ */
.gyl-link {
	display:inline-flex; align-items:center; gap: 6px;
	color: var(--gyl-gold);
	font-family: var(--gyl-font-mono);
	letter-spacing: .04em;
	font-size: 13px;
	text-transform: uppercase;
}
.gyl-link:hover { color: var(--gyl-gold-soft); text-decoration: none; }

/* ============================================================ *
 *  SERVICE PAGES — deep template (distinct from tool pages)
 * ============================================================ */

/* HERO */
.gyl-svc-hero {
	position: relative;
	min-height: 540px;
	padding: 120px 0 80px;
	background:
		linear-gradient(180deg, rgba(8,8,10,.9) 0%, rgba(8,8,10,.75) 50%, rgba(20,20,22,.92) 100%),
		var(--gyl-hero-bg, linear-gradient(135deg, #0a0a0c 0%, #1a1a1f 100%));
	background-size: cover;
	background-position: center;
	color: #f7f1e3;
	overflow: hidden;
}
.gyl-svc-hero--has-bg::before {
	content: "";
	position: absolute; inset: 0;
	background: radial-gradient(ellipse at center, rgba(212,175,55,.10) 0%, transparent 60%);
	pointer-events: none;
}
.gyl-svc-hero__inner { position: relative; z-index: 2; max-width: 880px; margin: 0 auto; }
.gyl-svc-hero__eyebrow {
	display: inline-block;
	color: var(--gyl-gold);
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 13px; letter-spacing: .12em; text-transform: uppercase;
	padding: 6px 14px; border: 1px solid rgba(212,175,55,.4); border-radius: 999px;
	margin-bottom: 22px;
}
.gyl-svc-hero__title {
	font-size: clamp(36px, 5.4vw, 60px);
	font-weight: 600; line-height: 1.08; letter-spacing: -0.015em;
	margin: 0 0 20px;
	color: #fff;
}
.gyl-svc-hero__title strong, .gyl-svc-hero__title em {
	color: var(--gyl-gold); font-style: normal; font-weight: 600;
}
.gyl-svc-hero__lede { font-size: clamp(17px, 1.4vw, 20px); line-height: 1.55; opacity: .85; max-width: 720px; margin: 0 0 32px; }
.gyl-svc-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 48px; }
.gyl-svc-hero__stats {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
	list-style: none; padding: 0; margin: 0;
	border-top: 1px solid rgba(247,241,227,.15); padding-top: 28px;
}
.gyl-svc-hero__stat-num {
	display: block; font-size: clamp(24px, 2.8vw, 36px); font-weight: 600; color: var(--gyl-gold); letter-spacing: -0.02em;
}
.gyl-svc-hero__stat-label { display: block; font-size: 13px; opacity: .7; margin-top: 4px; line-height: 1.4; }
@media (max-width: 720px) {
	.gyl-svc-hero__stats { grid-template-columns: repeat(2, 1fr); }
}

/* SHARED H2 */
.gyl-svc-section__h2 {
	font-size: clamp(26px, 3.2vw, 36px); font-weight: 600; line-height: 1.15;
	margin: 0 0 16px; letter-spacing: -0.015em;
}
.gyl-svc-section__lead { font-size: 17px; line-height: 1.6; opacity: .8; margin: 0 0 32px; max-width: 760px; }

/* TLDR */
.gyl-svc-tldr-wrap { padding: 0; margin-top: -50px; position: relative; z-index: 5; }
.gyl-svc-tldr {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
	background: #fff;
	border: 1px solid rgba(212,175,55,.2);
	border-radius: 16px;
	box-shadow: 0 30px 60px -20px rgba(0,0,0,.4), 0 0 0 1px rgba(212,175,55,.08);
	overflow: hidden;
}
.gyl-svc-tldr--3cells { grid-template-columns: repeat(3, 1fr); }
.gyl-svc-tldr--2cells { grid-template-columns: repeat(2, 1fr); }
.gyl-svc-tldr--1cells { grid-template-columns: 1fr; }
.gyl-svc-tldr__cell {
	padding: 24px 28px;
	border-right: 1px solid rgba(0,0,0,.06);
	display: flex; flex-direction: column; gap: 6px;
}
.gyl-svc-tldr__cell:last-child { border-right: none; }
.gyl-svc-tldr__label {
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: rgba(0,0,0,.5);
}
.gyl-svc-tldr__value { font-size: 15px; line-height: 1.5; color: #1a1a1f; }
.gyl-svc-tldr__value strong { color: var(--gyl-gold-deep, #b08c2c); }
@media (max-width: 900px) {
	.gyl-svc-tldr { grid-template-columns: repeat(2, 1fr); }
	.gyl-svc-tldr__cell:nth-child(2) { border-right: none; }
	.gyl-svc-tldr__cell:nth-child(1), .gyl-svc-tldr__cell:nth-child(2) { border-bottom: 1px solid rgba(0,0,0,.06); }
}
@media (max-width: 540px) {
	.gyl-svc-tldr { grid-template-columns: 1fr; }
	.gyl-svc-tldr__cell { border-right: none; border-bottom: 1px solid rgba(0,0,0,.06); }
	.gyl-svc-tldr__cell:last-child { border-bottom: none; }
}

/* DEFINITION */
.gyl-svc-definition { padding: 80px 0 40px; }
.gyl-svc-definition__inner { max-width: 820px; margin: 0 auto; }
.gyl-svc-definition__h2 { font-size: clamp(28px, 3.4vw, 40px); margin-bottom: 20px; }
.gyl-svc-definition__body { font-size: 18px; line-height: 1.65; color: #2a2a2e; }
.gyl-svc-definition__body code {
	background: rgba(212,175,55,.12); color: var(--gyl-gold-deep, #b08c2c);
	padding: 2px 8px; border-radius: 4px; font-size: .9em;
}

/* PILLARS */
.gyl-svc-pillars { padding: 80px 0; background: linear-gradient(180deg, transparent 0%, rgba(212,175,55,.03) 100%); }
.gyl-svc-pillars__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 1px; background: rgba(0,0,0,.08); border-radius: 16px; overflow: hidden; }
.gyl-svc-pillars__item {
	display: grid; grid-template-columns: 88px 1fr; gap: 28px;
	padding: 32px 36px; background: #fff;
	transition: background .2s ease;
}
.gyl-svc-pillars__item:hover { background: rgba(212,175,55,.04); }
.gyl-svc-pillars__num {
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 36px; font-weight: 500; color: var(--gyl-gold);
	letter-spacing: -0.04em; line-height: 1;
}
.gyl-svc-pillars__h3 { font-size: 22px; font-weight: 600; margin: 0 0 8px; letter-spacing: -0.01em; }
.gyl-svc-pillars__body p { margin: 0; font-size: 16px; line-height: 1.65; color: #3a3a40; }
.gyl-svc-pillars__body code { background: rgba(212,175,55,.12); color: var(--gyl-gold-deep, #b08c2c); padding: 2px 6px; border-radius: 4px; font-size: .88em; }
@media (max-width: 640px) {
	.gyl-svc-pillars__item { grid-template-columns: 1fr; padding: 24px 22px; gap: 8px; }
	.gyl-svc-pillars__num { font-size: 28px; }
}

/* COST OF INACTION */
.gyl-svc-cost {
	background: linear-gradient(135deg, #0a0a0c 0%, #1a1a1f 100%);
	color: #f7f1e3; padding: 80px 0;
}
.gyl-svc-cost__inner { max-width: 980px; margin: 0 auto; }
.gyl-svc-cost__inner .gyl-svc-section__h2 { color: #fff; }
.gyl-svc-cost__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
	margin: 32px 0 40px;
}
.gyl-svc-cost__stat {
	padding: 22px 24px;
	border: 1px solid rgba(247,241,227,.12);
	border-radius: 12px;
	background: rgba(247,241,227,.03);
}
.gyl-svc-cost__num {
	display: block; font-size: clamp(24px, 2.6vw, 32px); font-weight: 600; color: var(--gyl-gold);
	letter-spacing: -0.02em; margin-bottom: 8px;
}
.gyl-svc-cost__desc { display: block; font-size: 14px; line-height: 1.5; opacity: .8; }
.gyl-svc-cost__pull {
	font-size: clamp(20px, 2.2vw, 26px); font-weight: 500; line-height: 1.4;
	color: #fff; margin: 0; padding: 0; border: none;
	border-left: 3px solid var(--gyl-gold);
	padding-left: 24px;
	font-style: normal;
}
@media (max-width: 900px) { .gyl-svc-cost__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .gyl-svc-cost__grid { grid-template-columns: 1fr; } }

/* ANTI-PATTERN */
.gyl-svc-anti { padding: 80px 0; background: #fff; }
.gyl-svc-anti__inner { max-width: 920px; margin: 0 auto; }
.gyl-svc-anti__list { list-style: none; padding: 0; margin: 32px 0 0; display: grid; gap: 16px; }
.gyl-svc-anti__list li {
	display: grid; grid-template-columns: 28px 1fr; gap: 18px;
	align-items: start;
	padding: 24px 28px;
	background: rgba(255,236,236,.4);
	border-left: 3px solid #c63a3a;
	border-radius: 8px;
}
.gyl-svc-anti__list li::before {
	content: "✕"; color: #c63a3a; font-weight: 600; font-size: 22px;
	line-height: 1.3;
	grid-column: 1; grid-row: 1;
}
.gyl-svc-anti__copy { grid-column: 2; grid-row: 1; min-width: 0; }
.gyl-svc-anti__fail-title { display: block; font-size: 17px; font-weight: 600; margin-bottom: 6px; color: #1a1a1f; line-height: 1.4; }
.gyl-svc-anti__fail-body { display: block; font-size: 15px; line-height: 1.6; color: #3a3a40; }
.gyl-svc-anti__fail-body code { background: rgba(0,0,0,.06); padding: 2px 6px; border-radius: 4px; font-size: .9em; }

/* PROCESS TIMELINE */
.gyl-svc-process { padding: 80px 0; background: linear-gradient(180deg, rgba(212,175,55,.03) 0%, transparent 100%); }
.gyl-svc-process__list {
	list-style: none; padding: 0; margin: 32px 0 0;
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
	position: relative;
}
.gyl-svc-process__list::before {
	content: ""; position: absolute; top: 22px; left: 8%; right: 8%; height: 2px;
	background: linear-gradient(90deg, var(--gyl-gold) 0%, var(--gyl-gold) 100%);
	opacity: .3; z-index: 0;
}
.gyl-svc-process__step {
	position: relative; z-index: 1; padding: 0 16px;
	text-align: left;
}
.gyl-svc-process__when {
	display: inline-block; padding: 8px 14px;
	background: var(--gyl-gold); color: #1a1a1f;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 12px; font-weight: 600; letter-spacing: .04em;
	border-radius: 999px; margin-bottom: 16px;
}
.gyl-svc-process__h3 { font-size: 18px; font-weight: 600; margin: 0 0 8px; line-height: 1.3; }
.gyl-svc-process__step p { margin: 0; font-size: 14px; line-height: 1.6; color: #3a3a40; }
@media (max-width: 900px) {
	.gyl-svc-process__list { grid-template-columns: 1fr; gap: 24px; }
	.gyl-svc-process__list::before { display: none; }
	.gyl-svc-process__step { padding: 0; padding-left: 24px; border-left: 2px solid rgba(212,175,55,.3); }
}

/* DELIVERABLES */
.gyl-svc-deliverables { padding: 80px 0; }
.gyl-svc-deliverables__grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 32px;
}
.gyl-svc-deliverables__row {
	border: 1px solid rgba(212,175,55,.2);
	border-radius: 12px;
	padding: 28px 32px;
	background: #fff;
}
.gyl-svc-deliverables__phase {
	display: inline-block; padding: 6px 12px;
	background: rgba(212,175,55,.12); color: var(--gyl-gold-deep, #b08c2c);
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 12px; font-weight: 600; letter-spacing: .04em;
	border-radius: 6px; margin-bottom: 16px;
}
.gyl-svc-deliverables__items { list-style: none; padding: 0; margin: 0; }
.gyl-svc-deliverables__items li {
	padding: 8px 0 8px 28px; position: relative;
	font-size: 15px; line-height: 1.5;
}
.gyl-svc-deliverables__items li::before {
	content: "✓"; position: absolute; left: 0; top: 8px;
	color: var(--gyl-gold); font-weight: 600;
}
@media (max-width: 720px) { .gyl-svc-deliverables__grid { grid-template-columns: 1fr; } }

/* MISTAKES */
.gyl-svc-mistakes { padding: 80px 0; background: rgba(0,0,0,.02); }
.gyl-svc-mistakes__list { list-style: none; padding: 0; margin: 32px 0 0; counter-reset: mistakes; display: grid; gap: 14px; }
.gyl-svc-mistakes__list li {
	counter-increment: mistakes;
	display: grid; grid-template-columns: 36px 1fr; gap: 20px;
	align-items: start;
	padding: 20px 24px; background: #fff; border-radius: 10px;
	border: 1px solid rgba(0,0,0,.06);
}
.gyl-svc-mistakes__list li::before {
	content: counter(mistakes);
	display: flex; align-items: center; justify-content: center;
	width: 36px; height: 36px;
	background: rgba(198,58,58,.1); color: #c63a3a;
	border-radius: 50%;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 14px; font-weight: 600;
	grid-column: 1; grid-row: 1;
}
.gyl-svc-mistakes__copy { grid-column: 2; grid-row: 1; min-width: 0; }
.gyl-svc-mistakes__list strong { display: block; font-size: 16px; margin-bottom: 4px; color: #1a1a1f; }
.gyl-svc-mistakes__list span { display: block; font-size: 14.5px; line-height: 1.6; color: #3a3a40; }
.gyl-svc-mistakes__list code { background: rgba(0,0,0,.06); padding: 2px 6px; border-radius: 4px; font-size: .88em; }
.gyl-svc-mistakes__list code { background: rgba(0,0,0,.06); padding: 2px 6px; border-radius: 4px; font-size: .88em; }

/* PRICING */
.gyl-svc-pricing { padding: 80px 0; }
.gyl-svc-pricing__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 32px;
}
.gyl-svc-pricing__tier {
	background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 16px;
	padding: 36px 32px; position: relative;
	transition: transform .2s ease, box-shadow .2s ease;
}
.gyl-svc-pricing__tier:hover { transform: translateY(-2px); box-shadow: 0 16px 32px -16px rgba(0,0,0,.18); }
.gyl-svc-pricing__tier--featured {
	border: 2px solid var(--gyl-gold);
	box-shadow: 0 12px 32px -12px rgba(212,175,55,.4);
}
.gyl-svc-pricing__flag {
	position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
	background: var(--gyl-gold); color: #1a1a1f;
	padding: 6px 14px; border-radius: 999px;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
}
.gyl-svc-pricing__h3 { font-size: 20px; font-weight: 600; margin: 0 0 16px; }
.gyl-svc-pricing__price { font-size: 38px; font-weight: 600; color: var(--gyl-gold); letter-spacing: -0.02em; line-height: 1; }
.gyl-svc-pricing__price strong { font-weight: 600; }
.gyl-svc-pricing__sub { font-size: 14px; opacity: .7; margin: 8px 0 24px; min-height: 36px; }
.gyl-svc-pricing__list { list-style: none; padding: 0; margin: 0 0 28px; }
.gyl-svc-pricing__list li {
	padding: 8px 0 8px 28px; position: relative; font-size: 14.5px; line-height: 1.5;
	border-bottom: 1px solid rgba(0,0,0,.04);
}
.gyl-svc-pricing__list li:last-child { border-bottom: none; }
.gyl-svc-pricing__list li::before {
	content: "✓"; position: absolute; left: 0; top: 8px; color: var(--gyl-gold); font-weight: 600;
}
@media (max-width: 900px) { .gyl-svc-pricing__grid { grid-template-columns: 1fr; gap: 16px; } }

/* PAIRS-WITH TOOLS */
.gyl-svc-pairs { padding: 80px 0; background: rgba(212,175,55,.04); }
.gyl-svc-pairs__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 32px;
}
.gyl-svc-pairs__card {
	display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center;
	padding: 20px 24px; background: #fff;
	border: 1px solid rgba(0,0,0,.06); border-radius: 10px;
	text-decoration: none; color: inherit;
	transition: transform .2s ease, border-color .2s ease;
}
.gyl-svc-pairs__card:hover {
	transform: translateY(-2px); border-color: var(--gyl-gold);
}
.gyl-svc-pairs__card > div { grid-column: 1 / 2; }
.gyl-svc-pairs__name { display: block; font-size: 16px; font-weight: 600; margin-bottom: 4px; color: #1a1a1f; }
.gyl-svc-pairs__tagline { display: block; font-size: 13.5px; line-height: 1.5; color: #3a3a40; }
.gyl-svc-pairs__arrow { color: var(--gyl-gold); font-size: 22px; font-weight: 300; }
@media (max-width: 900px) { .gyl-svc-pairs__grid { grid-template-columns: 1fr; } }

/* ============================================================ *
 *  SERVICE PAGES — supplementary sections (takeaway, proof, author)
 * ============================================================ */

/* KEY TAKEAWAY (top, scanner-friendly) */
.gyl-svc-takeaway { padding: 36px 0 0; }
.gyl-svc-takeaway__inner {
	max-width: 880px; margin: 0 auto;
	padding: 22px 28px;
	background: linear-gradient(135deg, rgba(212,175,55,.08) 0%, rgba(212,175,55,.02) 100%);
	border-left: 4px solid var(--gyl-gold);
	border-radius: 8px;
}
.gyl-svc-takeaway__label {
	display: inline-block;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: var(--gyl-gold-deep, #b08c2c);
	margin-bottom: 8px;
}
.gyl-svc-takeaway__body {
	font-size: 18px; line-height: 1.55; color: #1a1a1f; margin: 0;
	font-weight: 500;
}
@media (max-width: 640px) {
	.gyl-svc-takeaway__inner { padding: 18px 22px; }
	.gyl-svc-takeaway__body { font-size: 16.5px; }
}

/* PROOF / WHY US */
.gyl-svc-proof {
	padding: 80px 0;
	background: linear-gradient(180deg, transparent 0%, rgba(212,175,55,.03) 100%);
}
.gyl-svc-proof__inner { max-width: 1080px; margin: 0 auto; }
.gyl-svc-proof__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
	margin-top: 32px;
}
.gyl-svc-proof__cell {
	padding: 28px 24px;
	background: #fff;
	border: 1px solid rgba(212,175,55,.2);
	border-radius: 12px;
	text-align: left;
	transition: transform .2s ease, box-shadow .2s ease;
}
.gyl-svc-proof__cell:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 32px -16px rgba(0,0,0,.18);
	border-color: var(--gyl-gold);
}
.gyl-svc-proof__num {
	display: block;
	font-size: clamp(28px, 3vw, 36px);
	font-weight: 600; color: var(--gyl-gold);
	letter-spacing: -0.02em; line-height: 1;
	margin-bottom: 12px;
}
.gyl-svc-proof__label {
	display: block; font-size: 14px; line-height: 1.5; color: #3a3a40;
}
.gyl-svc-proof__pull {
	margin: 32px 0 0; padding: 20px 24px;
	font-size: clamp(17px, 1.6vw, 20px); line-height: 1.5;
	border-left: 3px solid var(--gyl-gold);
	color: #1a1a1f;
	background: rgba(212,175,55,.04);
	border-radius: 0 8px 8px 0;
	font-style: normal;
}
@media (max-width: 900px) { .gyl-svc-proof__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .gyl-svc-proof__grid { grid-template-columns: 1fr; } }

/* AUTHOR CALLOUT */
.gyl-svc-author {
	padding: 60px 0 80px;
	background: linear-gradient(180deg, #fff 0%, rgba(0,0,0,.02) 100%);
}
.gyl-svc-author__inner {
	max-width: 920px; margin: 0 auto;
	display: grid; grid-template-columns: 140px 1fr; gap: 32px; align-items: start;
	padding: 32px 36px;
	background: #fff;
	border: 1px solid rgba(212,175,55,.2);
	border-radius: 16px;
	box-shadow: 0 16px 40px -20px rgba(0,0,0,.12);
}
.gyl-svc-author__photo {
	width: 120px; height: 120px;
	border-radius: 50%; object-fit: cover;
	border: 3px solid var(--gyl-gold);
	display: block;
}
.gyl-svc-author__label {
	display: inline-block;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: var(--gyl-gold-deep, #b08c2c);
	margin-bottom: 8px;
}
.gyl-svc-author__name {
	font-size: 22px; font-weight: 600; margin: 0 0 14px;
	letter-spacing: -0.01em; color: #1a1a1f;
}
.gyl-svc-author__bio {
	font-size: 15.5px; line-height: 1.65; color: #3a3a40;
	margin: 0 0 16px;
}
.gyl-svc-author__bio a { color: var(--gyl-gold-deep, #b08c2c); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.gyl-svc-author__bio strong { color: #1a1a1f; }
.gyl-svc-author__links {
	display: flex; flex-wrap: wrap; gap: 8px 12px;
	font-size: 14px; color: #6a6a70;
}
.gyl-svc-author__links a {
	color: var(--gyl-gold-deep, #b08c2c); text-decoration: none; font-weight: 500;
}
.gyl-svc-author__links a:hover { text-decoration: underline; }
@media (max-width: 720px) {
	.gyl-svc-author__inner { grid-template-columns: 1fr; padding: 24px 22px; gap: 16px; text-align: left; }
	.gyl-svc-author__photo { width: 100px; height: 100px; }
}

/* ============================================================ *
 *  SERVICE PAGES — peer-services strip + framework wheel
 * ============================================================ */

/* PEER SERVICES STRIP — lateral nav between sibling services */
.gyl-svc-peers {
	padding: 16px 0 8px;
	border-bottom: 1px solid rgba(0,0,0,.05);
}
.gyl-svc-peers .gyl-container {
	display: flex; align-items: center; gap: 16px;
}
.gyl-svc-peers__label {
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: rgba(0,0,0,.55);
	white-space: nowrap;
	flex-shrink: 0;
}
.gyl-svc-peers__scroll {
	display: flex; gap: 8px;
	overflow-x: auto;
	scroll-behavior: smooth;
	padding: 8px 4px;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}
.gyl-svc-peers__scroll::-webkit-scrollbar { height: 4px; }
.gyl-svc-peers__scroll::-webkit-scrollbar-thumb { background: rgba(212,175,55,.3); border-radius: 2px; }
.gyl-svc-peers__pill {
	display: inline-block;
	padding: 6px 14px;
	background: #fff;
	border: 1px solid rgba(0,0,0,.08);
	border-radius: 999px;
	font-size: 13px; font-weight: 500;
	color: #3a3a40;
	text-decoration: none;
	white-space: nowrap;
	transition: all .15s ease;
}
.gyl-svc-peers__pill:hover {
	border-color: var(--gyl-gold);
	color: var(--gyl-gold-deep, #b08c2c);
	background: rgba(212,175,55,.05);
}
.gyl-svc-peers__pill--current {
	background: var(--gyl-gold);
	color: #1a1a1f !important;
	border-color: var(--gyl-gold);
	font-weight: 600;
	pointer-events: none;
}
@media (max-width: 720px) {
	.gyl-svc-peers .gyl-container { flex-direction: column; align-items: flex-start; gap: 8px; }
	.gyl-svc-peers__scroll { width: 100%; }
}

/* FRAMEWORK WHEEL — visual anchor for the pillars section */
.gyl-svc-wheel {
	display: flex; justify-content: center; align-items: center;
	margin: 28px 0 40px;
}
.gyl-svc-wheel svg {
	width: 100%; max-width: 360px; height: auto;
}
@media (max-width: 480px) {
	.gyl-svc-wheel svg { max-width: 280px; }
}

/* ============================================================ *
 *  SERVICE PAGES — per-service unique block (5 type variants)
 * ============================================================ */
.gyl-svc-unique { padding: 80px 0; }
.gyl-svc-unique__inner { max-width: 980px; margin: 0 auto; }
.gyl-svc-unique__eyebrow {
	display: inline-block;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: var(--gyl-gold-deep, #b08c2c);
	margin-bottom: 12px;
}
.gyl-svc-unique__body { font-size: 16px; line-height: 1.65; color: #2a2a2e; }

/* TYPE: comparison (us vs generic agency) */
.gyl-svc-unique--comparison { background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.02) 100%); }
.gyl-svc-unique__compare {
	margin-top: 28px;
	border: 1px solid rgba(0,0,0,.08);
	border-radius: 12px; overflow: hidden;
	background: #fff;
}
.gyl-svc-unique__compare-head,
.gyl-svc-unique__compare-row {
	display: grid; grid-template-columns: 1.4fr 1fr 1fr;
}
.gyl-svc-unique__compare-head {
	background: #1a1a1f; color: #f7f1e3;
	padding: 14px 20px;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 12px; letter-spacing: .08em; text-transform: uppercase;
}
.gyl-svc-unique__col-bad { color: rgba(247,241,227,.55); }
.gyl-svc-unique__col-good { color: var(--gyl-gold); }
.gyl-svc-unique__compare-row {
	padding: 16px 20px;
	border-top: 1px solid rgba(0,0,0,.06);
	font-size: 14.5px; line-height: 1.55;
	align-items: start;
	gap: 16px;
}
.gyl-svc-unique__compare-axis { font-weight: 600; color: #1a1a1f; }
.gyl-svc-unique__compare-bad { color: #6a6a70; text-decoration: line-through; text-decoration-color: rgba(198,58,58,.45); }
.gyl-svc-unique__compare-good { color: var(--gyl-gold-deep, #b08c2c); font-weight: 500; }
@media (max-width: 720px) {
	.gyl-svc-unique__compare-head,
	.gyl-svc-unique__compare-row {
		grid-template-columns: 1fr;
		gap: 6px;
	}
	.gyl-svc-unique__compare-bad::before { content: "× "; }
	.gyl-svc-unique__compare-good::before { content: "✓ "; }
}

/* TYPE: integrations (logo-style grid of supported systems) */
.gyl-svc-unique__integrations {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
	margin-top: 28px;
}
.gyl-svc-unique__int-item {
	padding: 18px 20px;
	background: #fff;
	border: 1px solid rgba(212,175,55,.2);
	border-radius: 10px;
	text-align: center;
	transition: border-color .15s ease, transform .15s ease;
}
.gyl-svc-unique__int-item:hover { border-color: var(--gyl-gold); transform: translateY(-2px); }
.gyl-svc-unique__int-name {
	display: block;
	font-size: 16px; font-weight: 600; color: #1a1a1f;
	margin-bottom: 4px;
}
.gyl-svc-unique__int-note {
	display: block;
	font-size: 12px; color: #6a6a70;
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
}
@media (max-width: 720px) { .gyl-svc-unique__integrations { grid-template-columns: repeat(2, 1fr); } }

/* TYPE: mini-stats (3-card stat grid) */
.gyl-svc-unique__stats {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
	margin-top: 28px;
}
.gyl-svc-unique__stat-card {
	padding: 28px;
	background: linear-gradient(135deg, #fff 0%, rgba(212,175,55,.05) 100%);
	border: 1px solid rgba(212,175,55,.25);
	border-radius: 12px;
}
.gyl-svc-unique__stat-num {
	display: block;
	font-size: clamp(32px, 4vw, 48px); font-weight: 600; color: var(--gyl-gold);
	letter-spacing: -0.02em; line-height: 1; margin-bottom: 12px;
}
.gyl-svc-unique__stat-label { display: block; font-size: 14px; line-height: 1.55; color: #3a3a40; }
@media (max-width: 720px) { .gyl-svc-unique__stats { grid-template-columns: 1fr; } }

/* TYPE: list (key-value, like a glossary) */
.gyl-svc-unique__list {
	list-style: none; padding: 0; margin: 28px 0 0;
	display: grid; gap: 0;
	border-top: 1px solid rgba(0,0,0,.06);
}
.gyl-svc-unique__list li {
	display: grid; grid-template-columns: 1fr 2fr; gap: 24px;
	padding: 18px 0;
	border-bottom: 1px solid rgba(0,0,0,.06);
}
.gyl-svc-unique__list-key {
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 13px; letter-spacing: .04em;
	color: var(--gyl-gold-deep, #b08c2c);
	font-weight: 600;
}
.gyl-svc-unique__list-val { font-size: 15px; line-height: 1.6; color: #2a2a2e; }
@media (max-width: 640px) {
	.gyl-svc-unique__list li { grid-template-columns: 1fr; gap: 4px; }
}

/* TYPE: callout (free-form prose box, default) */
.gyl-svc-unique--callout .gyl-svc-unique__body {
	margin-top: 28px;
	padding: 28px 32px;
	background: linear-gradient(135deg, rgba(212,175,55,.06) 0%, rgba(212,175,55,.02) 100%);
	border-left: 4px solid var(--gyl-gold);
	border-radius: 8px;
	font-size: 16.5px;
}

/* ================================================================ *
 *  COUNTRY-DEEP PAGES — distinct visual identity from service pages
 * ================================================================ */

.gyl-cnt-hero {
	position: relative; min-height: 480px; padding: 100px 0 60px;
	background: linear-gradient(180deg, rgba(8,8,10,.92) 0%, rgba(8,8,10,.78) 50%, rgba(20,20,22,.94) 100%), var(--gyl-hero-bg, linear-gradient(135deg, #0a0a0c 0%, #1a1a1f 100%));
	background-size: cover; background-position: center;
	color: #f7f1e3; overflow: hidden;
}
.gyl-cnt-hero::before {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(ellipse at top, rgba(212,175,55,.08) 0%, transparent 60%);
	pointer-events: none;
}
.gyl-cnt-hero__inner { position: relative; z-index: 2; max-width: 920px; margin: 0 auto; text-align: center; }
.gyl-cnt-hero__flag { font-size: 56px; display: block; margin-bottom: 16px; opacity: .85; }
.gyl-cnt-hero__eyebrow {
	display: inline-block; padding: 6px 14px;
	border: 1px solid rgba(212,175,55,.45); border-radius: 999px;
	color: var(--gyl-gold);
	font-family: var(--gyl-font-mono, 'JetBrains Mono', monospace);
	font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
	margin-bottom: 22px;
}
.gyl-cnt-hero__title {
	font-size: clamp(36px, 5.4vw, 60px); font-weight: 600; line-height: 1.08;
	letter-spacing: -.015em; margin: 0 0 20px; color: #fff;
}
.gyl-cnt-hero__lede { font-size: clamp(17px, 1.4vw, 20px); line-height: 1.55; opacity: .85; max-width: 720px; margin: 0 auto 32px; }
.gyl-cnt-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

.gyl-cnt-section__h2 { font-size: clamp(26px, 3.2vw, 36px); font-weight: 600; line-height: 1.15; margin: 0 0 16px; letter-spacing: -.015em; }
.gyl-cnt-section__lead { font-size: 17px; line-height: 1.6; opacity: .8; margin: 0 0 32px; max-width: 760px; }

/* COUNTRY: by-the-numbers */
.gyl-cnt-numbers { padding: 80px 0; background: linear-gradient(180deg, rgba(212,175,55,.04) 0%, transparent 100%); }
.gyl-cnt-numbers__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 28px; }
.gyl-cnt-numbers__cell {
	padding: 28px 24px; background: #fff;
	border: 1px solid rgba(212,175,55,.2); border-radius: 12px;
	transition: transform .15s ease, box-shadow .15s ease;
}
.gyl-cnt-numbers__cell:hover { transform: translateY(-2px); box-shadow: 0 16px 32px -16px rgba(0,0,0,.18); border-color: var(--gyl-gold); }
.gyl-cnt-numbers__num { display: block; font-size: clamp(28px, 3vw, 36px); font-weight: 600; color: var(--gyl-gold); letter-spacing: -.02em; line-height: 1; margin-bottom: 12px; }
.gyl-cnt-numbers__label { display: block; font-size: 14px; line-height: 1.5; color: #2a2a2e; }
.gyl-cnt-numbers__source { display: block; margin-top: 10px; font-size: 11px; opacity: .55; font-family: var(--gyl-font-mono, monospace); }
@media (max-width: 900px) { .gyl-cnt-numbers__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .gyl-cnt-numbers__grid { grid-template-columns: 1fr; } }

/* COUNTRY: context block */
.gyl-cnt-context { padding: 80px 0; }
.gyl-cnt-context__inner { max-width: 920px; margin: 0 auto; }
.gyl-cnt-context__body { font-size: 17px; line-height: 1.7; color: #2a2a2e; }
.gyl-cnt-context__body p { margin: 0 0 16px; }
.gyl-cnt-context__highlights { list-style: none; padding: 0; margin: 32px 0 0; display: grid; gap: 0; border-top: 1px solid rgba(0,0,0,.06); }
.gyl-cnt-context__highlights li { display: grid; grid-template-columns: 220px 1fr; gap: 24px; padding: 18px 0; border-bottom: 1px solid rgba(0,0,0,.06); }
.gyl-cnt-context__h-key { font-family: var(--gyl-font-mono, monospace); font-size: 12px; letter-spacing: .04em; color: var(--gyl-gold-deep, #b08c2c); font-weight: 600; text-transform: uppercase; padding-top: 2px; }
.gyl-cnt-context__h-val { font-size: 15px; line-height: 1.6; color: #2a2a2e; }
@media (max-width: 640px) { .gyl-cnt-context__highlights li { grid-template-columns: 1fr; gap: 4px; } }

/* COUNTRY: regions grid */
.gyl-cnt-regions { padding: 80px 0; background: rgba(0,0,0,.02); }
.gyl-cnt-regions__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 28px; }
.gyl-cnt-regions__card {
	display: flex; align-items: center; gap: 12px;
	padding: 18px 20px; background: #fff;
	border: 1px solid rgba(0,0,0,.08); border-radius: 10px;
	text-decoration: none; color: inherit;
	transition: all .15s ease;
}
.gyl-cnt-regions__card:hover { border-color: var(--gyl-gold); transform: translateY(-2px); }
.gyl-cnt-regions__name { display: block; font-size: 15px; font-weight: 600; color: #1a1a1f; flex: 1; }
.gyl-cnt-regions__hint { display: block; font-size: 11px; color: rgba(0,0,0,.5); font-family: var(--gyl-font-mono, monospace); }
.gyl-cnt-regions__arrow { color: var(--gyl-gold); font-size: 18px; }
@media (max-width: 900px) { .gyl-cnt-regions__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .gyl-cnt-regions__grid { grid-template-columns: 1fr; } }

/* COUNTRY: competitor cards */
.gyl-cnt-competitors { padding: 80px 0; }
.gyl-cnt-competitors__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 28px; }
.gyl-cnt-competitors__card {
	padding: 28px; background: linear-gradient(135deg, #fff 0%, rgba(212,175,55,.03) 100%);
	border: 1px solid rgba(212,175,55,.2); border-radius: 12px;
}
.gyl-cnt-competitors__type { display: inline-block; font-family: var(--gyl-font-mono, monospace); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--gyl-gold-deep, #b08c2c); margin-bottom: 10px; }
.gyl-cnt-competitors__h3 { font-size: 18px; font-weight: 600; margin: 0 0 10px; color: #1a1a1f; }
.gyl-cnt-competitors__card p { margin: 0 0 12px; font-size: 14.5px; line-height: 1.6; color: #3a3a40; }
.gyl-cnt-competitors__play { display: block; font-size: 13.5px; line-height: 1.55; color: #3a3a40; padding-top: 10px; border-top: 1px dashed rgba(0,0,0,.1); }
@media (max-width: 900px) { .gyl-cnt-competitors__grid { grid-template-columns: 1fr; } }

/* COUNTRY: services + tools cards (shared style) */
.gyl-cnt-services { padding: 80px 0; }
.gyl-cnt-services__grid,
.gyl-cnt-tools__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 28px; }
.gyl-cnt-services__card,
.gyl-cnt-tools__card {
	padding: 24px 26px; background: #fff;
	border: 1px solid rgba(0,0,0,.08); border-radius: 10px;
	text-decoration: none; color: inherit;
	transition: all .15s ease; display: block;
}
.gyl-cnt-services__card:hover,
.gyl-cnt-tools__card:hover { border-color: var(--gyl-gold); transform: translateY(-2px); }
.gyl-cnt-services__h3 { font-size: 17px; font-weight: 600; margin: 0 0 8px; color: #1a1a1f; }
.gyl-cnt-services__card p { margin: 0 0 12px; font-size: 14px; line-height: 1.6; color: #3a3a40; }
.gyl-cnt-services__arrow,
.gyl-cnt-tools__arrow { color: var(--gyl-gold); font-size: 14px; font-weight: 500; }
.gyl-cnt-tools { padding: 80px 0; background: rgba(212,175,55,.04); }
.gyl-cnt-tools__name { display: block; font-size: 16px; font-weight: 600; color: #1a1a1f; margin-bottom: 4px; }
.gyl-cnt-tools__tagline { display: block; font-size: 13.5px; line-height: 1.5; color: #3a3a40; margin-bottom: 12px; }
@media (max-width: 720px) {
	.gyl-cnt-services__grid, .gyl-cnt-tools__grid { grid-template-columns: 1fr; }
}

/* ================================================================ *
 *  STATE-DEEP PAGES — distinct from country & service pages
 * ================================================================ */

.gyl-st-hero {
	position: relative; min-height: 440px; padding: 80px 0 60px;
	background: linear-gradient(180deg, rgba(8,8,10,.93) 0%, rgba(8,8,10,.82) 100%), var(--gyl-hero-bg, linear-gradient(135deg, #0a0a0c 0%, #1a1a1f 100%));
	background-size: cover; background-position: center;
	color: #f7f1e3;
}
.gyl-st-hero__inner { position: relative; z-index: 2; max-width: 880px; margin: 0 auto; }
.gyl-st-hero__breadcrumb-pill {
	display: inline-block; padding: 6px 14px;
	border: 1px solid rgba(247,241,227,.2); border-radius: 999px;
	background: rgba(247,241,227,.04);
	font-family: var(--gyl-font-mono, monospace); font-size: 12px; letter-spacing: .04em;
	color: rgba(247,241,227,.85); margin-bottom: 18px;
}
.gyl-st-hero__breadcrumb-pill a { color: var(--gyl-gold); text-decoration: none; }
.gyl-st-hero__breadcrumb-pill a:hover { text-decoration: underline; }
.gyl-st-hero__title { font-size: clamp(32px, 4.6vw, 50px); font-weight: 600; line-height: 1.1; letter-spacing: -.015em; margin: 0 0 20px; color: #fff; }
.gyl-st-hero__lede { font-size: clamp(16px, 1.3vw, 18px); line-height: 1.55; opacity: .85; max-width: 720px; margin: 0 0 28px; }
.gyl-st-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px; }
.gyl-st-hero__facts { list-style: none; padding: 24px 0 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; border-top: 1px solid rgba(247,241,227,.15); }
.gyl-st-hero__fact-label { display: block; font-family: var(--gyl-font-mono, monospace); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: rgba(247,241,227,.55); margin-bottom: 6px; }
.gyl-st-hero__fact-val { display: block; font-size: 15px; font-weight: 500; color: var(--gyl-gold); }
@media (max-width: 720px) { .gyl-st-hero__facts { grid-template-columns: repeat(2, 1fr); } }

.gyl-st-section__h2 { font-size: clamp(24px, 2.8vw, 32px); font-weight: 600; line-height: 1.2; margin: 0 0 16px; letter-spacing: -.012em; }
.gyl-st-section__lead { font-size: 16px; line-height: 1.6; opacity: .8; margin: 0 0 28px; max-width: 760px; }

/* STATE: intro */
.gyl-st-intro { padding: 60px 0 0; }
.gyl-st-intro__inner { max-width: 820px; margin: 0 auto; }
.gyl-st-intro__body { font-size: 17px; line-height: 1.75; color: #2a2a2e; }
.gyl-st-intro__body p { margin: 0 0 16px; }

/* STATE: cities table */
.gyl-st-cities { padding: 80px 0; }
.gyl-st-cities__table {
	margin-top: 28px;
	border: 1px solid rgba(0,0,0,.08); border-radius: 12px;
	background: #fff; overflow: hidden;
}
.gyl-st-cities__head,
.gyl-st-cities__row { display: grid; grid-template-columns: 1.2fr 1.5fr 2fr; gap: 24px; padding: 14px 24px; }
.gyl-st-cities__head {
	background: #1a1a1f; color: #f7f1e3;
	font-family: var(--gyl-font-mono, monospace); font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
}
.gyl-st-cities__row {
	border-top: 1px solid rgba(0,0,0,.06); align-items: center;
	transition: background .15s ease;
}
.gyl-st-cities__row:hover { background: rgba(212,175,55,.03); }
.gyl-st-cities__city { font-weight: 600; color: #1a1a1f; font-size: 15px; }
.gyl-st-cities__zip code { background: rgba(212,175,55,.1); color: var(--gyl-gold-deep, #b08c2c); padding: 4px 8px; border-radius: 4px; font-size: 13px; font-weight: 500; }
.gyl-st-cities__intent { font-size: 14px; line-height: 1.5; color: #3a3a40; }
@media (max-width: 720px) {
	.gyl-st-cities__head { display: none; }
	.gyl-st-cities__row { grid-template-columns: 1fr; gap: 6px; padding: 18px 22px; }
}

/* STATE: popular places — local SEO entity references */
.gyl-st-places { padding: 80px 0; background: linear-gradient(180deg, rgba(212,175,55,.03) 0%, transparent 100%); }
.gyl-st-places__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 28px; }
.gyl-st-places__card {
	padding: 22px 24px; background: #fff;
	border: 1px solid rgba(212,175,55,.18); border-radius: 12px;
	display: flex; flex-direction: column; gap: 6px;
	transition: border-color .15s ease, transform .15s ease;
}
.gyl-st-places__card:hover { border-color: var(--gyl-gold); transform: translateY(-2px); }
.gyl-st-places__category {
	display: inline-block; padding: 3px 10px;
	background: rgba(212,175,55,.1); color: var(--gyl-gold-deep, #b08c2c);
	font-family: var(--gyl-font-mono, monospace); font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
	border-radius: 4px; align-self: flex-start; margin-bottom: 6px;
}
.gyl-st-places__name { font-size: 17px; font-weight: 600; margin: 0; color: #1a1a1f; line-height: 1.3; }
.gyl-st-places__city { font-size: 13px; color: rgba(0,0,0,.55); }
.gyl-st-places__why { margin: 4px 0 12px; font-size: 14px; line-height: 1.55; color: #3a3a40; }
.gyl-st-places__gmb {
	margin-top: auto;
	font-size: 13px; font-weight: 500;
	color: var(--gyl-gold-deep, #b08c2c);
	text-decoration: none;
	display: inline-flex; align-items: center; gap: 4px;
}
.gyl-st-places__gmb:hover { text-decoration: underline; }
@media (max-width: 900px) { .gyl-st-places__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .gyl-st-places__grid { grid-template-columns: 1fr; } }

/* STATE: competitors numbered list */
.gyl-st-competitors { padding: 80px 0; }
.gyl-st-competitors__list { list-style: none; padding: 0; margin: 28px 0 0; counter-reset: stcomp; display: grid; gap: 12px; }
.gyl-st-competitors__list li {
	counter-increment: stcomp;
	display: grid; grid-template-columns: auto 1fr; gap: 18px;
	padding: 20px 24px; background: #fff;
	border: 1px solid rgba(0,0,0,.06); border-radius: 10px;
	align-items: start;
}
.gyl-st-competitors__list li::before {
	content: counter(stcomp);
	display: flex; align-items: center; justify-content: center;
	width: 32px; height: 32px; flex-shrink: 0;
	background: rgba(212,175,55,.12); color: var(--gyl-gold-deep, #b08c2c);
	border-radius: 50%;
	font-family: var(--gyl-font-mono, monospace); font-size: 13px; font-weight: 600;
}
.gyl-st-competitors__copy { display: flex; flex-direction: column; gap: 4px; }
.gyl-st-competitors__type { font-family: var(--gyl-font-mono, monospace); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: rgba(0,0,0,.55); }
.gyl-st-competitors__copy strong { font-size: 16px; color: #1a1a1f; }
.gyl-st-competitors__copy span:last-child { font-size: 14.5px; line-height: 1.6; color: #3a3a40; }

/* STATE: occasion + services + tools */
.gyl-st-occasion { padding: 80px 0; background: rgba(0,0,0,.02); }
.gyl-st-occasion__inner { max-width: 920px; margin: 0 auto; }
.gyl-st-occasion__body { font-size: 16.5px; line-height: 1.7; color: #2a2a2e; }
.gyl-st-occasion__body p { margin: 0 0 14px; }
.gyl-st-services,
.gyl-st-tools { padding: 80px 0; }
.gyl-st-services__grid,
.gyl-st-tools__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 28px; }
.gyl-st-services__card,
.gyl-st-tools__card {
	padding: 22px 24px; background: #fff;
	border: 1px solid rgba(0,0,0,.08); border-radius: 10px;
	text-decoration: none; color: inherit;
	transition: all .15s ease; display: block;
}
.gyl-st-services__card:hover,
.gyl-st-tools__card:hover { border-color: var(--gyl-gold); transform: translateY(-2px); }
.gyl-st-services__h3 { font-size: 16px; font-weight: 600; margin: 0 0 8px; color: #1a1a1f; }
.gyl-st-services__card p { margin: 0; font-size: 14px; line-height: 1.55; color: #3a3a40; }
.gyl-st-tools { background: rgba(212,175,55,.04); }
.gyl-st-tools__name { display: block; font-size: 15px; font-weight: 600; color: #1a1a1f; margin-bottom: 4px; }
.gyl-st-tools__tagline { display: block; font-size: 13px; line-height: 1.5; color: #3a3a40; margin-bottom: 10px; }
.gyl-st-tools__arrow { color: var(--gyl-gold); font-size: 14px; }
@media (max-width: 720px) {
	.gyl-st-services__grid, .gyl-st-tools__grid { grid-template-columns: 1fr; }
}

/* STATE: sibling state pills */
.gyl-st-siblings { padding: 60px 0; }
.gyl-st-siblings__pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.gyl-st-siblings__pill {
	padding: 8px 14px; background: #fff;
	border: 1px solid rgba(0,0,0,.08); border-radius: 999px;
	font-size: 13px; color: #3a3a40; text-decoration: none;
	transition: all .15s ease;
}
.gyl-st-siblings__pill:hover { border-color: var(--gyl-gold); color: var(--gyl-gold-deep, #b08c2c); }

/* ================================================================ *
 *  TOOL-DEEP PAGES — distinct from country/state/service pages
 * ================================================================ */

.gyl-tl-hero {
	position: relative; min-height: 420px; padding: 90px 0 50px;
	background: linear-gradient(180deg, rgba(8,8,10,.92) 0%, rgba(8,8,10,.74) 70%, rgba(20,20,22,.92) 100%), var(--gyl-hero-bg, linear-gradient(135deg, #0a0a0c 0%, #1a1a1f 100%));
	background-size: cover; background-position: center;
	color: #f7f1e3;
}
.gyl-tl-hero__inner { position: relative; z-index: 2; max-width: 880px; margin: 0 auto; }
.gyl-tl-hero__eyebrow {
	display: inline-block; padding: 6px 14px;
	border: 1px solid rgba(212,175,55,.45); border-radius: 999px;
	color: var(--gyl-gold);
	font-family: var(--gyl-font-mono, monospace);
	font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
	margin-bottom: 20px;
}
.gyl-tl-hero__title { font-size: clamp(32px, 4.6vw, 48px); font-weight: 600; line-height: 1.12; letter-spacing: -.015em; margin: 0 0 18px; color: #fff; }
.gyl-tl-hero__lede { font-size: clamp(16px, 1.3vw, 19px); line-height: 1.55; opacity: .85; max-width: 720px; margin: 0 0 28px; }
.gyl-tl-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px; }
.gyl-tl-hero__facts { list-style: none; padding: 24px 0 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; border-top: 1px solid rgba(247,241,227,.15); }
.gyl-tl-hero__fact-num { display: block; font-size: clamp(20px, 2.4vw, 28px); font-weight: 600; color: var(--gyl-gold); letter-spacing: -.02em; line-height: 1; margin-bottom: 4px; }
.gyl-tl-hero__fact-label { display: block; font-size: 12px; line-height: 1.4; opacity: .75; }
@media (max-width: 720px) { .gyl-tl-hero__facts { grid-template-columns: repeat(2, 1fr); } }

.gyl-tl-section__h2 { font-size: clamp(24px, 2.8vw, 32px); font-weight: 600; line-height: 1.2; margin: 0 0 16px; letter-spacing: -.012em; }

/* TOOL: widget host (the actual plugin shortcode) */
.gyl-tl-widget {
	padding: 50px 0;
	background: linear-gradient(180deg, rgba(212,175,55,.04) 0%, rgba(212,175,55,.01) 100%);
	border-bottom: 1px solid rgba(212,175,55,.15);
	scroll-margin-top: 100px;
}
.gyl-tl-widget__inner { max-width: 980px; margin: 0 auto; }

/* TOOL: what-it-does + steps */
.gyl-tl-what { padding: 80px 0; }
.gyl-tl-what__inner { max-width: 920px; margin: 0 auto; }
.gyl-tl-what__body { font-size: 16.5px; line-height: 1.7; color: #2a2a2e; margin-bottom: 28px; }
.gyl-tl-what__body p { margin: 0 0 14px; }
.gyl-tl-what__steps { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.gyl-tl-what__steps li {
	display: grid; grid-template-columns: auto 1fr; gap: 18px;
	padding: 20px 24px; background: #fff;
	border: 1px solid rgba(0,0,0,.06); border-radius: 10px;
}
.gyl-tl-what__num {
	font-family: var(--gyl-font-mono, monospace);
	font-size: 24px; font-weight: 500; color: var(--gyl-gold);
	letter-spacing: -.03em; line-height: 1;
}
.gyl-tl-what__step-copy { display: flex; flex-direction: column; gap: 4px; }
.gyl-tl-what__step-copy strong { font-size: 16px; color: #1a1a1f; }
.gyl-tl-what__step-copy span { font-size: 14.5px; line-height: 1.6; color: #3a3a40; }

/* TOOL: use-cases (best for / not for split) */
.gyl-tl-usecases { padding: 80px 0; background: rgba(0,0,0,.02); }
.gyl-tl-usecases__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 28px; }
.gyl-tl-usecases__col { padding: 28px 32px; background: #fff; border-radius: 12px; border: 1px solid rgba(0,0,0,.06); }
.gyl-tl-usecases__col h3 {
	font-family: var(--gyl-font-mono, monospace);
	font-size: 12px; letter-spacing: .12em; text-transform: uppercase;
	margin: 0 0 16px; color: rgba(0,0,0,.6);
}
.gyl-tl-usecases__col--for h3 { color: #2a8a3e; }
.gyl-tl-usecases__col--not h3 { color: #c63a3a; }
.gyl-tl-usecases__col ul { list-style: none; padding: 0; margin: 0; }
.gyl-tl-usecases__col li {
	padding: 8px 0 8px 28px; position: relative;
	font-size: 15px; line-height: 1.55; color: #2a2a2e;
	border-bottom: 1px solid rgba(0,0,0,.04);
}
.gyl-tl-usecases__col li:last-child { border-bottom: none; }
.gyl-tl-usecases__col--for li::before { content: "✓"; position: absolute; left: 0; top: 8px; color: #2a8a3e; font-weight: 600; }
.gyl-tl-usecases__col--not li::before { content: "×"; position: absolute; left: 0; top: 6px; color: #c63a3a; font-weight: 600; font-size: 18px; }
@media (max-width: 720px) { .gyl-tl-usecases__grid { grid-template-columns: 1fr; } }

/* TOOL: alternatives comparison cards */
.gyl-tl-alts { padding: 80px 0; }
.gyl-tl-alts__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 28px; }
.gyl-tl-alts__card {
	padding: 24px 26px; background: #fff;
	border: 1px solid rgba(212,175,55,.18); border-radius: 12px;
}
.gyl-tl-alts__name { display: block; font-size: 17px; font-weight: 600; color: #1a1a1f; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid rgba(0,0,0,.06); }
.gyl-tl-alts__pro { margin: 0 0 10px; font-size: 14px; line-height: 1.55; color: #2a2a2e; }
.gyl-tl-alts__con { margin: 0; font-size: 14px; line-height: 1.55; color: #2a2a2e; }
.gyl-tl-alts__pro strong { color: #2a8a3e; }
.gyl-tl-alts__con strong { color: #c63a3a; }
@media (max-width: 900px) { .gyl-tl-alts__grid { grid-template-columns: 1fr; } }

/* TOOL: ROI math */
.gyl-tl-roi { padding: 80px 0; background: linear-gradient(135deg, #0a0a0c 0%, #1a1a1f 100%); color: #f7f1e3; }
.gyl-tl-roi__inner { max-width: 880px; margin: 0 auto; }
.gyl-tl-roi__inner .gyl-tl-section__h2 { color: #fff; }
.gyl-tl-roi__body { font-size: 17px; line-height: 1.7; opacity: .9; }
.gyl-tl-roi__body p { margin: 0 0 14px; }
.gyl-tl-roi__eq {
	margin-top: 28px; padding: 24px 28px;
	background: rgba(247,241,227,.06);
	border-left: 4px solid var(--gyl-gold);
	border-radius: 0 8px 8px 0;
	font-family: var(--gyl-font-mono, monospace);
	font-size: 17px; line-height: 1.7; color: var(--gyl-gold);
}

/* TOOL: pairs-services + related-tools (link cards) */
.gyl-tl-pairs,
.gyl-tl-related { padding: 80px 0; }
.gyl-tl-pairs { background: rgba(0,0,0,.02); }
.gyl-tl-pairs__grid,
.gyl-tl-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 28px; }
.gyl-tl-pairs__card,
.gyl-tl-related__card {
	padding: 22px 24px; background: #fff;
	border: 1px solid rgba(0,0,0,.08); border-radius: 10px;
	text-decoration: none; color: inherit;
	transition: all .15s ease; display: block;
}
.gyl-tl-pairs__card:hover,
.gyl-tl-related__card:hover { border-color: var(--gyl-gold); transform: translateY(-2px); }
.gyl-tl-pairs__h3 { font-size: 17px; font-weight: 600; margin: 0 0 8px; color: #1a1a1f; }
.gyl-tl-pairs__card p { margin: 0 0 12px; font-size: 14px; line-height: 1.6; color: #3a3a40; }
.gyl-tl-pairs__arrow { color: var(--gyl-gold); font-size: 14px; font-weight: 500; }
.gyl-tl-related__name { display: block; font-size: 16px; font-weight: 600; color: #1a1a1f; margin-bottom: 4px; }
.gyl-tl-related__tagline { display: block; font-size: 13px; line-height: 1.55; color: #3a3a40; margin-bottom: 10px; }
.gyl-tl-related__arrow { color: var(--gyl-gold); font-size: 14px; }
@media (max-width: 900px) {
	.gyl-tl-pairs__grid, .gyl-tl-related__grid { grid-template-columns: 1fr; }
}
