/*!
Theme Name: gemzavana
Theme URI: http://underscores.me/
Author: kasiryelabs
Author URI: http://kasiryelabs.com
Description: Gem Zavanna is a creative arts agency working at the intersection of creative practice, cultural systems, and the structures that shape sustainable creative careers.  We focus on how creative work actually functions beyond talent — the policies, platforms, funding mechanisms, informal economies, and institutional decisions that determine who gets to create, who gets supported, and who gets left out.
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: gemzavana
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

gemzavana is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* =============================================================
   GEM ZAVANNA BRAND SYSTEM
   Brand Guidelines · April 2026
   ============================================================= */

/* Brand Color Variables
--------------------------------------------- */
:root {
	--gz-deep-indigo:   #1f0c31;
	--gz-purple:        #5c3a8e;
	--gz-teal:          #00687a;
	--gz-gold:          #fad02c;
	--gz-gold-dark:     #e8c000;
	--gz-gold-darker:   #d4a700;
	--gz-savanna-gold:  #b59f78;
	--gz-ivory:         #faf7f0;
	--gz-purple-dark:   #4a2f74;

	/* Typography */
	--gz-font-heading: 'Merriweather', Georgia, serif;
	--gz-font-body:    'Montserrat', 'Segoe UI', sans-serif;

	/* Spacing scale */
	--gz-space-xs:  5px;
	--gz-space-sm:  10px;
	--gz-space-md:  15px;
	--gz-space-lg:  20px;
	--gz-space-xl:  30px;
	--gz-space-2xl: 40px;
	--gz-space-3xl: 60px;
	--gz-space-4xl: 80px;
}

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
	color: var(--gz-deep-indigo);
	font-family: var(--gz-font-body);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
	font-family: var(--gz-font-heading);
	font-weight: 700;
	color: var(--gz-deep-indigo);
	line-height: 1.2;
}

h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.375rem; }
h4 { font-size: 1.125rem; color: var(--gz-purple); }
h5 { font-size: 1rem; color: var(--gz-purple); font-family: var(--gz-font-body); font-weight: 600; }
h6 { font-size: 0.875rem; color: var(--gz-teal); font-family: var(--gz-font-body); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/* Elements
--------------------------------------------- */

/* Text selection — gold highlight on deep indigo text */
::selection {
	background-color: var(--gz-gold);
	color: var(--gz-deep-indigo);
}

::-moz-selection {
	background-color: var(--gz-gold);
	color: var(--gz-deep-indigo);
}

body {
	background: var(--gz-ivory);
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 1.5em 3em;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: 700;
}

dd {
	margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

img {
	height: auto;
	max-width: 100%;
}

figure {
	margin: 1em 0;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/* Links
--------------------------------------------- */
a {
	color: var(--gz-teal);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:visited {
	color: var(--gz-purple);
}

a:hover,
a:focus,
a:active {
	color: var(--gz-deep-indigo);
	text-decoration: underline;
	text-decoration-color: var(--gz-gold);
}

a:focus {
	outline: 2px solid var(--gz-gold);
	outline-offset: 2px;
}

a:hover,
a:active {
	outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	display: inline-block;
	background: var(--gz-gold);
	color: var(--gz-deep-indigo);
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	font-weight: 700;
	border: none;
	border-radius: 4px;
	padding: 15px 30px;
	min-height: 48px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	text-decoration: none;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	background: var(--gz-gold-dark);
	transform: translateY(-2px);
	box-shadow: 0 8px 15px rgba(31, 12, 49, 0.2);
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	background: var(--gz-gold-darker);
	outline: 2px solid var(--gz-deep-indigo);
	outline-offset: 2px;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: var(--gz-deep-indigo);
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	background: var(--gz-ivory);
	border: 1px solid rgba(31, 12, 49, 0.2);
	border-radius: 4px;
	padding: 12px 16px;
	width: 100%;
	transition: border-color 0.2s ease;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: var(--gz-deep-indigo);
	border-color: var(--gz-teal);
	outline: 2px solid rgba(0, 104, 122, 0.2);
	outline-offset: 0;
}

select {
	color: var(--gz-deep-indigo);
	font-family: var(--gz-font-body);
	border: 1px solid rgba(31, 12, 49, 0.2);
	border-radius: 4px;
	padding: 12px 16px;
	background: var(--gz-ivory);
}

textarea {
	width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.main-navigation {
	display: block;
	width: 100%;
	background: var(--gz-deep-indigo);
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	background: var(--gz-deep-indigo);
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
	min-width: 200px;
	border-top: 2px solid var(--gz-gold);
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	display: block;
	left: auto;
}

.main-navigation ul ul a {
	width: 200px;
	color: var(--gz-ivory);
	padding: 12px 20px;
	font-size: 0.8125rem;
}

.main-navigation ul ul a:hover {
	color: var(--gz-gold);
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: auto;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	text-decoration: none;
	color: var(--gz-ivory);
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	font-weight: 500;
	padding: 16px 20px;
	transition: color 0.2s ease;
}

.main-navigation a:hover,
.main-navigation a:focus {
	color: var(--gz-gold);
	text-decoration: none;
}

.main-navigation a:visited {
	color: var(--gz-ivory);
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

.menu-toggle {
	background: transparent;
	border: 1px solid var(--gz-ivory);
	color: var(--gz-ivory);
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	font-weight: 500;
	padding: 10px 20px;
	min-height: 44px;
	cursor: pointer;
}

.menu-toggle:hover {
	background: var(--gz-gold);
	color: var(--gz-deep-indigo);
	border-color: var(--gz-gold);
	transform: none;
	box-shadow: none;
}

@media screen and (min-width: 37.5em) {

	.menu-toggle {
		display: none;
	}

	.main-navigation ul {
		display: flex;
	}
}

.site-main .comment-navigation,
.site-main
.posts-navigation,
.site-main
.post-navigation {
	margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
	display: block;
}

.post,
.page {
	margin: 0 0 1.5em;
}

.updated:not(.published) {
	display: none;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
	margin: 0 0 1.5em;
}

.widget select {
	max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
	display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

/* Galleries
--------------------------------------------- */
.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
	grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
	display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {

	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {

	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}

/*--------------------------------------------------------------
# Elementor Brand Overrides
--------------------------------------------------------------*/

/* Default brand fonts for Elementor — no !important so Elementor typography controls can override */
.elementor-widget-heading .elementor-heading-title,
.elementor h1,
.elementor h2,
.elementor h3 {
	font-family: var(--gz-font-heading);
}

.elementor-widget-text-editor,
.elementor p,
.elementor .elementor-button,
.elementor-widget-button .elementor-button {
	font-family: var(--gz-font-body);
}

/* Primary button (Gold) */
.elementor-button.gz-btn-primary,
.gz-btn-primary {
	background-color: var(--gz-gold) !important;
	color: var(--gz-deep-indigo) !important;
	font-family: var(--gz-font-body) !important;
	font-weight: 700 !important;
	font-size: 0.875rem !important;
	border: none !important;
	border-radius: 4px !important;
	padding: 15px 30px !important;
	min-height: 48px !important;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
}

.elementor-button.gz-btn-primary:hover,
.gz-btn-primary:hover {
	background-color: var(--gz-gold-dark) !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 8px 15px rgba(31, 12, 49, 0.2) !important;
}

/* Secondary button (Purple) */
.elementor-button.gz-btn-secondary,
.gz-btn-secondary {
	background-color: var(--gz-purple) !important;
	color: var(--gz-ivory) !important;
	font-family: var(--gz-font-body) !important;
	font-weight: 700 !important;
	font-size: 0.875rem !important;
	border: none !important;
	border-radius: 4px !important;
	padding: 15px 30px !important;
	min-height: 48px !important;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
}

.elementor-button.gz-btn-secondary:hover,
.gz-btn-secondary:hover {
	background-color: var(--gz-purple-dark) !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 8px 15px rgba(92, 58, 142, 0.2) !important;
}

/* Gold divider line (for CTA sections) */
.gz-gold-divider {
	display: block;
	width: 60px;
	height: 2px;
	background: var(--gz-gold);
	margin: 0 auto var(--gz-space-xl);
}

/* Testimonial / pull quote block */
.gz-quote {
	border-left: 4px solid var(--gz-gold);
	padding: 30px 40px;
	background: linear-gradient(135deg, var(--gz-purple) 0%, var(--gz-deep-indigo) 100%);
	color: var(--gz-ivory);
	font-family: var(--gz-font-heading);
	font-style: italic;
	font-weight: 700;
	font-size: 1.125rem;
	line-height: 1.5;
}

/* Card with teal top border */
.gz-card {
	background: var(--gz-ivory);
	border-top: 3px solid var(--gz-teal);
	padding: var(--gz-space-xl);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.gz-card:hover {
	border-top-color: var(--gz-gold);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
	transform: translateY(-5px);
}

/* Service card — legacy rules removed, see Services Archive section */

/* Dark CTA section */
.gz-cta-section {
	background: var(--gz-deep-indigo);
	color: var(--gz-ivory);
	padding: var(--gz-space-3xl) var(--gz-space-2xl);
	text-align: center;
}

.gz-cta-section h2,
.gz-cta-section h3 {
	color: var(--gz-gold);
}

/* Ensure Elementor section backgrounds using Deep Indigo get Ivory text */
.elementor-section[data-settings*='"gz_dark"'] h1,
.elementor-section[data-settings*='"gz_dark"'] h2,
.elementor-section[data-settings*='"gz_dark"'] h3,
.elementor-section[data-settings*='"gz_dark"'] p {
	color: var(--gz-ivory);
}

/* Typography helpers */
.gz-text-purple  { color: var(--gz-purple); }
.gz-text-teal    { color: var(--gz-teal); }
.gz-text-gold    { color: var(--gz-gold); }
.gz-text-ivory   { color: var(--gz-ivory); }
.gz-text-indigo  { color: var(--gz-deep-indigo); }
.gz-bg-ivory     { background-color: var(--gz-ivory); }
.gz-bg-indigo    { background-color: var(--gz-deep-indigo); }
.gz-bg-purple    { background-color: var(--gz-purple); }

/* Hover animation for links */
.gz-link-gold {
	position: relative;
	color: var(--gz-teal);
	text-decoration: none;
}

.gz-link-gold::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--gz-gold);
	transition: width 0.3s ease;
}

.gz-link-gold:hover::after {
	width: 100%;
}

/*--------------------------------------------------------------
# Responsive Adjustments
--------------------------------------------------------------*/

@media screen and (max-width: 1199px) {
	h1 { font-size: 2rem; }
	h2 { font-size: 1.75rem; }
	h3 { font-size: 1.125rem; }
}

@media screen and (max-width: 767px) {
	h1 { font-size: 1.75rem; }
	h2 { font-size: 1.5rem; }
	h3 { font-size: 1rem; }

	button,
	input[type="button"],
	input[type="reset"],
	input[type="submit"] {
		width: 100%;
		text-align: center;
		padding: 12px 20px;
	}
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/

.gz-footer {
	background: var(--gz-ivory);
	border-top: 1px solid rgba(31, 12, 49, 0.1);
}

/* Main section */
.gz-footer__main {
	padding: var(--gz-space-4xl) 0 var(--gz-space-3xl);
}

.gz-footer__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--gz-space-2xl);
	display: grid;
	grid-template-columns: 1fr 1.2fr 1fr;
	gap: var(--gz-space-4xl);
	align-items: start;
}

/* Column 1 — brand */
.gz-footer__logo {
	margin-bottom: var(--gz-space-lg);
}

.gz-footer__logo img {
	max-width: 160px;
	height: auto;
}

.gz-footer__wordmark {
	font-family: var(--gz-font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	text-decoration: none;
}

.gz-footer__tagline {
	font-family: var(--gz-font-heading);
	font-style: italic;
	font-weight: 700;
	font-size: 0.9375rem;
	color: var(--gz-purple);
	margin: 0 0 var(--gz-space-sm);
	line-height: 1.4;
}

.gz-footer__desc {
	font-family: var(--gz-font-body);
	font-size: 0.8125rem;
	color: var(--gz-deep-indigo);
	opacity: 0.75;
	margin: 0 0 var(--gz-space-xl);
	line-height: 1.6;
}

/* Search */
.gz-footer__search-wrap {
	display: flex;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(31, 12, 49, 0.15);
	border-radius: 50px;
	overflow: hidden;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.gz-footer__search-wrap:focus-within {
	border-color: var(--gz-teal);
	box-shadow: 0 0 0 3px rgba(0, 104, 122, 0.12);
}

.gz-footer__search-input {
	flex: 1;
	border: none;
	background: transparent;
	padding: 12px 18px;
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	color: var(--gz-deep-indigo);
	outline: none;
	width: auto;
}

.gz-footer__search-input::placeholder {
	color: rgba(31, 12, 49, 0.45);
}

.gz-footer__search-btn {
	background: transparent;
	border: none;
	padding: 10px 16px;
	color: var(--gz-teal);
	cursor: pointer;
	display: flex;
	align-items: center;
	min-height: unset;
	width: auto;
	border-radius: 0;
	box-shadow: none;
	transition: color 0.2s ease;
}

.gz-footer__search-btn:hover {
	background: transparent;
	color: var(--gz-gold-dark);
	transform: none;
	box-shadow: none;
}

/* Column 2 — links */
.gz-footer__heading {
	font-family: var(--gz-font-body);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--gz-deep-indigo);
	margin: 0 0 var(--gz-space-xl);
	padding-bottom: var(--gz-space-sm);
	border-bottom: 1px solid rgba(31, 12, 49, 0.12);
}

.gz-footer__links-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 var(--gz-space-lg);
}

.gz-footer__nav-list,
.gz-footer__nav-list ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.gz-footer__nav-list li {
	margin-bottom: var(--gz-space-sm);
}

.gz-footer__nav-list a {
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	color: var(--gz-deep-indigo);
	text-decoration: none;
	opacity: 0.8;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.gz-footer__nav-list a:hover {
	color: var(--gz-teal);
	opacity: 1;
	text-decoration: none;
}

.gz-footer__nav-list a:visited {
	color: var(--gz-deep-indigo);
}

/* Column 3 — social card */
.gz-footer__social-card {
	background: var(--gz-gold);
	border-radius: 8px;
	padding: var(--gz-space-2xl) var(--gz-space-xl);
}

.gz-footer__social-heading {
	font-family: var(--gz-font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 var(--gz-space-sm);
	clear: none;
	line-height: 1.3;
}

.gz-footer__social-desc {
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	color: var(--gz-deep-indigo);
	margin: 0 0 var(--gz-space-xl);
	line-height: 1.6;
	opacity: 0.85;
}

.gz-footer__social-icons {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gz-space-sm);
}

.gz-footer__social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border: 2px solid var(--gz-deep-indigo);
	border-radius: 50%;
	color: var(--gz-deep-indigo);
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}

.gz-footer__social-link:hover {
	background: var(--gz-deep-indigo);
	color: var(--gz-gold);
	text-decoration: none;
}

.gz-footer__social-link:visited {
	color: var(--gz-deep-indigo);
}

.gz-footer__social-link svg {
	display: block;
	flex-shrink: 0;
}

/* Bottom bar */
.gz-footer__bottom {
	background: var(--gz-deep-indigo);
	padding: var(--gz-space-lg) 0;
}

.gz-footer__bottom-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--gz-space-2xl);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--gz-space-sm);
}

.gz-footer__copyright,
.gz-footer__credit {
	font-family: var(--gz-font-body);
	font-size: 0.6875rem;
	color: var(--gz-ivory);
	opacity: 0.6;
	margin: 0;
}

.gz-footer__credit a {
	color: var(--gz-ivory);
	opacity: 1;
	text-decoration: underline;
	text-decoration-color: var(--gz-gold);
}

.gz-footer__credit a:hover {
	color: var(--gz-gold);
	text-decoration-color: var(--gz-gold);
}

/* Footer responsive */
@media screen and (max-width: 1023px) {
	.gz-footer__inner {
		grid-template-columns: 1fr 1fr;
		gap: var(--gz-space-3xl) var(--gz-space-2xl);
	}

	.gz-footer__col--social {
		grid-column: 1 / -1;
	}

	.gz-footer__social-card {
		display: grid;
		grid-template-columns: 1fr auto;
		grid-template-rows: auto auto;
		gap: var(--gz-space-sm) var(--gz-space-xl);
		align-items: center;
	}

	.gz-footer__social-heading {
		grid-column: 1;
		grid-row: 1;
		margin: 0;
	}

	.gz-footer__social-desc {
		grid-column: 1;
		grid-row: 2;
		margin: 0;
	}

	.gz-footer__social-icons {
		grid-column: 2;
		grid-row: 1 / 3;
		flex-direction: row;
		justify-content: flex-end;
	}
}

@media screen and (max-width: 640px) {
	.gz-footer__inner {
		grid-template-columns: 1fr;
		gap: var(--gz-space-2xl);
	}

	.gz-footer__col--social {
		grid-column: auto;
	}

	.gz-footer__social-card {
		display: block;
	}

	.gz-footer__social-heading {
		margin-bottom: var(--gz-space-sm);
	}

	.gz-footer__social-desc {
		margin-bottom: var(--gz-space-lg);
	}

	.gz-footer__social-icons {
		flex-direction: row;
	}

	.gz-footer__links-grid {
		grid-template-columns: 1fr 1fr;
	}

	.gz-footer__bottom-inner {
		flex-direction: column;
		text-align: center;
		gap: var(--gz-space-xs);
	}
}

/*--------------------------------------------------------------
# Header — Transparent → Solid on scroll
--------------------------------------------------------------*/

/* ── Base ── */
.gz-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: transparent;
	transition: background 0.35s ease, box-shadow 0.35s ease;
}

/* Scrolled state — background + shadow */
.gz-header--scrolled {
	background: var(--gz-deep-indigo);
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}

/* ── Inner layout ── */
.gz-header__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--gz-space-2xl);
	height: 80px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--gz-space-xl);
}

/* ── Brand (left) ── */
.gz-header__brand {
	display: flex;
	align-items: center;
	gap: var(--gz-space-md);
	flex-shrink: 0;
	text-decoration: none;
}

.gz-header__logo img {
	height: 48px;
	width: auto;
	display: block;
}

.gz-header__brand-link {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	line-height: 1.2;
}

.gz-header__brand-link:hover {
	text-decoration: none;
}

.gz-header__brand-sub {
	font-family: var(--gz-font-body);
	font-size: 0.6875rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: rgba(250, 247, 240, 0.75);
}

.gz-header__brand-name {
	font-family: var(--gz-font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--gz-gold);
}

/* ── Right side ── */
.gz-header__right {
	display: flex;
	align-items: center;
	gap: var(--gz-space-lg);
}

/* ── Primary navigation ── */
.gz-header__nav.main-navigation {
	background: transparent;
}

.gz-header__nav #primary-menu {
	display: flex;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 4px;
}

.gz-header__nav #primary-menu > li {
	position: relative;
}

.gz-header__nav #primary-menu > li > a {
	display: flex;
	align-items: center;
	padding: 10px 14px;
	font-family: var(--gz-font-body);
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--gz-ivory);
	text-decoration: none;
	border-radius: 4px;
	transition: color 0.2s ease, background 0.2s ease;
	white-space: nowrap;
}

.gz-header__nav #primary-menu > li > a:visited {
	color: var(--gz-ivory);
}

.gz-header__nav #primary-menu > li > a:hover,
.gz-header__nav #primary-menu > li.focus > a,
.gz-header__nav #primary-menu > li.current-menu-item > a,
.gz-header__nav #primary-menu > li.current-menu-ancestor > a,
.gz-header__nav #primary-menu > li.current_page_item > a {
	color: var(--gz-gold);
	background: rgba(250, 208, 44, 0.08);
	text-decoration: none;
}

/* Active item underline */
.gz-header__nav #primary-menu > li.current-menu-item > a,
.gz-header__nav #primary-menu > li.current-menu-ancestor > a,
.gz-header__nav #primary-menu > li.current_page_item > a {
	color: var(--gz-gold);
	position: relative;
}

.gz-header__nav #primary-menu > li.current-menu-item > a::after,
.gz-header__nav #primary-menu > li.current_page_item > a::after {
	content: '';
	position: absolute;
	bottom: 4px;
	left: 14px;
	right: 14px;
	height: 2px;
	background: var(--gz-gold);
	border-radius: 2px;
}

/* ── Dropdown menus ── */
.gz-header__nav .sub-menu {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 200px;
	background: var(--gz-deep-indigo);
	border-top: 3px solid var(--gz-purple);
	border-radius: 0 0 6px 6px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
	list-style: none;
	margin: 0;
	padding: 8px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
	z-index: 100;
}

.gz-header__nav #primary-menu > li:hover > .sub-menu,
.gz-header__nav #primary-menu > li.focus > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.gz-header__nav .sub-menu li {
	position: relative;
}

.gz-header__nav .sub-menu a {
	display: block;
	padding: 10px 20px;
	font-family: var(--gz-font-body);
	font-size: 0.8125rem;
	font-weight: 400;
	color: var(--gz-ivory);
	text-decoration: none;
	transition: color 0.15s ease, padding-left 0.15s ease;
}

.gz-header__nav .sub-menu a:visited {
	color: var(--gz-ivory);
}

.gz-header__nav .sub-menu a:hover {
	color: var(--gz-gold);
	padding-left: 26px;
	text-decoration: none;
}

/* Nested sub-menus */
.gz-header__nav .sub-menu .sub-menu {
	top: 0;
	left: 100%;
	border-top: none;
	border-left: 3px solid var(--gz-purple);
	border-radius: 0 0 6px 6px;
}

/* ── Divider ── */
.gz-header__divider {
	display: block;
	width: 1px;
	height: 20px;
	background: rgba(250, 247, 240, 0.25);
	flex-shrink: 0;
}

/* ── Search toggle ── */
.gz-header__search-toggle {
	background: transparent;
	border: none;
	color: var(--gz-ivory);
	padding: 8px;
	min-height: unset;
	width: auto;
	border-radius: 4px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color 0.2s ease, background 0.2s ease;
	box-shadow: none;
}

.gz-header__search-toggle:hover {
	color: var(--gz-gold);
	background: rgba(250, 208, 44, 0.08);
	transform: none;
	box-shadow: none;
}

/* ── CTA button ── */
.gz-header__cta {
	display: inline-flex;
	align-items: center;
	padding: 10px 22px;
	background: var(--gz-purple);
	color: var(--gz-ivory);
	font-family: var(--gz-font-body);
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: 4px;
	text-decoration: none;
	white-space: nowrap;
	min-height: 42px;
	transition: background 0.2s ease, transform 0.15s ease;
	flex-shrink: 0;
}

.gz-header__cta:hover {
	background: var(--gz-gold);
	color: var(--gz-deep-indigo);
	text-decoration: none;
	transform: translateY(-1px);
}

.gz-header__cta:visited {
	color: var(--gz-ivory);
}

.gz-header__cta:hover:visited {
	color: var(--gz-deep-indigo);
}

/* ── Hamburger button ── */
.gz-header__hamburger {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	background: transparent;
	border: 1px solid rgba(250, 247, 240, 0.35);
	border-radius: 4px;
	width: 42px;
	height: 42px;
	padding: 0;
	min-height: unset;
	cursor: pointer;
	box-shadow: none;
	transition: border-color 0.2s ease, background 0.2s ease;
}

.gz-header__hamburger:hover {
	background: rgba(250, 247, 240, 0.08);
	border-color: var(--gz-gold);
	transform: none;
	box-shadow: none;
}

.gz-hamburger__bar {
	display: block;
	width: 20px;
	height: 2px;
	background: var(--gz-ivory);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.25s ease, width 0.25s ease;
}

/* Animate hamburger → ✕ when nav is open */
.gz-nav-open .gz-hamburger__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.gz-nav-open .gz-hamburger__bar:nth-child(2) {
	opacity: 0;
	width: 0;
}
.gz-nav-open .gz-hamburger__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ── Search panel ── */
.gz-header__search-panel {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--gz-deep-indigo);
	border-top: 1px solid rgba(250, 247, 240, 0.1);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
	transform: translateY(-100%);
	opacity: 0;
	transition: transform 0.3s ease, opacity 0.3s ease;
	pointer-events: none;
}

.gz-header__search-panel--open {
	transform: translateY(0);
	opacity: 1;
	pointer-events: auto;
}

/* hidden attr: override display so CSS transition still works */
.gz-header__search-panel[hidden] {
	display: block !important;
	visibility: hidden;
}

.gz-header__search-panel--open[hidden] {
	visibility: visible;
}

.gz-header__search-panel-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: var(--gz-space-lg) var(--gz-space-2xl);
	display: flex;
	align-items: center;
	gap: var(--gz-space-lg);
}

.gz-header__search-form {
	flex: 1;
	display: flex;
	align-items: center;
	border-bottom: 2px solid rgba(250, 247, 240, 0.2);
	transition: border-color 0.2s ease;
}

.gz-header__search-form:focus-within {
	border-bottom-color: var(--gz-gold);
}

.gz-header__search-form input[type="search"] {
	flex: 1;
	background: transparent;
	border: none;
	color: var(--gz-ivory);
	font-family: var(--gz-font-heading);
	font-size: 1.25rem;
	padding: 12px 0;
	outline: none;
	width: auto;
}

.gz-header__search-form input[type="search"]::placeholder {
	color: rgba(250, 247, 240, 0.4);
}

.gz-header__search-submit {
	background: transparent;
	border: none;
	color: var(--gz-gold);
	padding: 8px 12px;
	min-height: unset;
	width: auto;
	border-radius: 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	box-shadow: none;
	transition: opacity 0.2s ease;
}

.gz-header__search-submit:hover {
	opacity: 0.75;
	background: transparent;
	transform: none;
	box-shadow: none;
}

.gz-header__search-close {
	background: transparent;
	border: 1px solid rgba(250, 247, 240, 0.25);
	color: var(--gz-ivory);
	border-radius: 4px;
	width: 40px;
	height: 40px;
	padding: 0;
	min-height: unset;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: border-color 0.2s ease, color 0.2s ease;
	box-shadow: none;
}

.gz-header__search-close:hover {
	border-color: var(--gz-gold);
	color: var(--gz-gold);
	background: transparent;
	transform: none;
	box-shadow: none;
}

/* ── Body offset so content isn't hidden under fixed header ── */
body {
	padding-top: 80px;
}

/* Pages whose first section is a full-bleed hero remove the offset */
body.has-hero {
	padding-top: 0;
}

/* Pull all hero sections flush under the transparent fixed header */
body.has-hero .gz-blog-home__hero,
body.has-hero .gz-archive__hero,
body.has-hero .gz-single__hero,
body.has-hero .gz-team-archive__hero,
body.has-hero .gz-member__hero {
	margin-top: -80px;
	padding-top: calc(80px + 64px);
}

/* ── Responsive ── */
@media screen and (max-width: 1023px) {
	.gz-header__nav #primary-menu > li > a {
		padding: 10px 10px;
		font-size: 0.75rem;
	}

	.gz-header__cta {
		padding: 8px 16px;
		font-size: 0.75rem;
	}
}

@media screen and (max-width: 860px) {
	/* Show hamburger, hide desktop nav links */
	.gz-header__hamburger {
		display: flex;
	}

	.gz-header__divider {
		display: none;
	}

	/* Mobile nav panel */
	.gz-header__nav #primary-menu {
		display: none;
		flex-direction: column;
		position: absolute;
		top: 80px;
		left: 0;
		right: 0;
		background: var(--gz-deep-indigo);
		border-top: 1px solid rgba(250, 247, 240, 0.1);
		padding: var(--gz-space-lg) 0;
		box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
		gap: 0;
	}

	.gz-header__nav.toggled #primary-menu {
		display: flex;
	}

	.gz-header__nav #primary-menu > li > a {
		padding: 14px var(--gz-space-2xl);
		font-size: 0.875rem;
		border-radius: 0;
	}

	.gz-header__nav #primary-menu > li > a::after {
		display: none;
	}

	/* Mobile dropdowns */
	.gz-header__nav .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		border-top: none;
		border-left: 3px solid var(--gz-purple);
		border-radius: 0;
		background: rgba(0, 0, 0, 0.2);
		display: none;
		padding: 4px 0;
		margin: 0 0 0 var(--gz-space-2xl);
	}

	.gz-header__nav #primary-menu > li.focus > .sub-menu,
	.gz-header__nav #primary-menu > li:focus-within > .sub-menu {
		display: block;
	}

	.gz-header__nav .sub-menu a {
		padding: 10px var(--gz-space-2xl);
	}

	.gz-header__nav .sub-menu a:hover {
		padding-left: var(--gz-space-2xl);
	}
}

@media screen and (max-width: 640px) {
	.gz-header__inner {
		padding: 0 var(--gz-space-lg);
	}

	.gz-header__brand-name {
		font-size: 1rem;
	}

	.gz-header__brand-sub {
		display: none;
	}

	.gz-header__cta {
		display: none;
	}

	.gz-header__search-panel-inner {
		padding: var(--gz-space-md) var(--gz-space-lg);
	}

	.gz-header__search-form input[type="search"] {
		font-size: 1rem;
	}
}

/*--------------------------------------------------------------
# What We Offer — Elementor Widget
--------------------------------------------------------------*/

/* ── Wrapper ── */
.gz-wwo {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: var(--gz-deep-indigo);
}

/* ── Background image ── */
.gz-wwo__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transform: scale(1.04);
	transition: transform 12s ease;
}

.gz-wwo:hover .gz-wwo__bg {
	transform: scale(1);
}

/* ── Dark overlay ── */
.gz-wwo__overlay {
	position: absolute;
	inset: 0;
	background: var(--gz-deep-indigo);
	z-index: 1;
}

/* ── Inner content ── */
.gz-wwo__inner {
	position: relative;
	z-index: 2;
}

/* ── Heading ── */
.gz-wwo__heading {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--gz-gold);
	text-align: center;
	padding: clamp(40px, 6vw, 80px) var(--gz-space-2xl) clamp(20px, 3vw, 40px);
	margin: 0;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

/* ── Service list ── */
.gz-wwo__list {
	border-top: 1px solid rgba(250, 247, 240, 0.12);
}

/* ── Each service row ── */
.gz-wwo__item {
	--gz-accent: #00687a;

	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--gz-space-xl);
	padding: 28px clamp(24px, 5vw, 80px);
	border-bottom: 1px solid rgba(250, 247, 240, 0.12);
	text-decoration: none;
	overflow: hidden;
	cursor: pointer;
	transition: padding-left 0.4s ease;
}

/* Slide-in background on hover */
.gz-wwo__item::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--gz-accent);
	transform: translateX(-100%);
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
	z-index: 0;
}

.gz-wwo__item:hover::before,
.gz-wwo__item:focus-visible::before {
	transform: translateX(0);
}

/* ── Item content (keeps above the ::before layer) ── */
.gz-wwo__item-content {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.gz-wwo__item-name {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.25rem, 2.5vw, 2rem);
	font-weight: 700;
	color: var(--gz-ivory);
	line-height: 1.2;
	letter-spacing: -0.01em;
	transition: letter-spacing 0.4s ease;
}

.gz-wwo__item:hover .gz-wwo__item-name,
.gz-wwo__item:focus-visible .gz-wwo__item-name {
	letter-spacing: 0.01em;
}

.gz-wwo__item-desc {
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	color: rgba(250, 247, 240, 0.7);
	line-height: 1.5;
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.4s ease, opacity 0.3s ease 0.1s;
}

.gz-wwo__item:hover .gz-wwo__item-desc,
.gz-wwo__item:focus-visible .gz-wwo__item-desc {
	max-height: 60px;
	opacity: 1;
}

/* ── Arrow circle ── */
.gz-wwo__item-arrow {
	position: relative;
	z-index: 1;
	flex-shrink: 0;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: var(--gz-accent);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.35s ease, color 0.35s ease, transform 0.35s ease;
}

.gz-wwo__item:hover .gz-wwo__item-arrow,
.gz-wwo__item:focus-visible .gz-wwo__item-arrow {
	background: #fff;
	color: var(--gz-accent);
	transform: translateX(6px);
}

/* ── Bottom padding after list ── */
.gz-wwo__list + * ,
.gz-wwo__list:last-child {
	margin-bottom: 0;
}

.gz-wwo__inner > :last-child {
	padding-bottom: 0;
}

/* ── Responsive ── */
@media screen and (max-width: 767px) {
	.gz-wwo__item {
		padding: 22px var(--gz-space-lg);
		gap: var(--gz-space-md);
	}

	.gz-wwo__item-arrow {
		width: 40px;
		height: 40px;
	}

	.gz-wwo__item-desc {
		display: none; /* too cramped on mobile */
	}
}

/*--------------------------------------------------------------
# Hero Slider
--------------------------------------------------------------*/

/* ── Wrapper ── */
.gz-hero-slider {
	position: relative;
	width: 100%;
	height: 100vh;
	min-height: 600px;
	overflow: hidden;
	background: var(--gz-deep-indigo);
	outline: none;
}

/* On pages with .has-hero, slider cancels the header offset */
body.has-hero .gz-hero-slider {
	margin-top: -80px;
}

/* ── Track ── */
.gz-slider__track {
	position: absolute;
	inset: 0;
}

/* ── Individual Slide ── */
.gz-slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0;
	transition: opacity 0.9s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
	z-index: 1;
}

.gz-slide--active {
	opacity: 1;
	pointer-events: auto;
	z-index: 3;
}

.gz-slide--leaving {
	opacity: 0;
	z-index: 2;
}

/* ── Gradient backgrounds (placeholders until real photos are added) ── */
.gz-slide--bg-1 {
	background-image:
		radial-gradient(ellipse at 80% 20%, rgba(92, 58, 142, 0.25) 0%, transparent 60%),
		linear-gradient(145deg, #1f0c31 0%, #221038 40%, #0d3340 100%);
}

.gz-slide--bg-2 {
	background-image:
		radial-gradient(ellipse at 20% 80%, rgba(0, 104, 122, 0.5) 0%, transparent 55%),
		radial-gradient(ellipse at 75% 15%, rgba(92, 58, 142, 0.15) 0%, transparent 50%),
		linear-gradient(160deg, #0d1f31 0%, #1f0c31 50%, #003040 100%);
}

.gz-slide--bg-3 {
	background-image:
		radial-gradient(ellipse at 30% 30%, rgba(250, 208, 44, 0.08) 0%, transparent 50%),
		radial-gradient(ellipse at 70% 70%, rgba(0, 104, 122, 0.45) 0%, transparent 55%),
		linear-gradient(135deg, #180620 0%, #1f0c31 55%, #003844 100%);
}

/* When a real background-image is set inline, add a tinted overlay via the overlay div */
.gz-slide[style*="background-image"] {
	background-size: cover;
	background-position: center;
}

/* ── Dark overlay (also serves as parallax layer) ── */
.gz-slide__overlay {
	position: absolute;
	inset: -5%; /* slightly oversized for parallax shift */
	background: linear-gradient(
		to bottom,
		rgba(31, 12, 49, 0.15) 0%,
		rgba(31, 12, 49, 0.55) 50%,
		rgba(31, 12, 49, 0.92) 100%
	);
	transition: transform 0.4s ease;
	z-index: 1;
}

/* ── Decorative large background number ── */
.gz-slide__number-bg {
	position: absolute;
	bottom: -0.1em;
	right: 5%;
	font-family: var(--gz-font-heading);
	font-size: clamp(12rem, 30vw, 26rem);
	font-weight: 700;
	line-height: 1;
	color: rgba(250, 247, 240, 0.03);
	pointer-events: none;
	user-select: none;
	z-index: 2;
	letter-spacing: -0.05em;
}

/* ── Decorative gem SVG ── */
.gz-slide__gem {
	position: absolute;
	top: 50%;
	right: 8%;
	transform: translateY(-50%);
	width: clamp(160px, 22vw, 320px);
	color: var(--gz-gold);
	pointer-events: none;
	user-select: none;
	z-index: 2;
	opacity: 0;
	transition: opacity 1s ease 0.2s;
}

.gz-slide--active .gz-slide__gem {
	opacity: 1;
}

/* ── Content area ── */
.gz-slide__content {
	position: relative;
	z-index: 4;
	width: 100%;
	padding-top: 80px; /* header height */
}

.gz-slide__content-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 var(--gz-space-2xl);
	max-width: 700px;
	margin-left: max(var(--gz-space-2xl), calc((100vw - 1280px) / 2 + var(--gz-space-2xl)));
}

/* ── Content elements — hidden then animated in ── */
.gz-slide__eyebrow,
.gz-slide__divider,
.gz-slide__headline,
.gz-slide__desc,
.gz-slide__actions {
	opacity: 0;
	transform: translateY(36px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.gz-slide--active .gz-slide__eyebrow  { opacity: 1; transform: translateY(0); transition-delay: 0.35s; }
.gz-slide--active .gz-slide__divider  { opacity: 1; transform: translateY(0); transition-delay: 0.5s;  }
.gz-slide--active .gz-slide__headline { opacity: 1; transform: translateY(0); transition-delay: 0.6s;  }
.gz-slide--active .gz-slide__desc     { opacity: 1; transform: translateY(0); transition-delay: 0.78s; }
.gz-slide--active .gz-slide__actions  { opacity: 1; transform: translateY(0); transition-delay: 0.92s; }

/* Eyebrow */
.gz-slide__eyebrow {
	font-family: var(--gz-font-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gz-teal);
	margin: 0 0 var(--gz-space-lg);
}

/* Gold divider line */
.gz-slide__divider {
	width: 48px;
	height: 3px;
	background: var(--gz-gold);
	border-radius: 2px;
	margin: 0 0 var(--gz-space-xl);
}

/* Headline */
.gz-slide__headline {
	font-family: var(--gz-font-heading);
	font-size: clamp(2.25rem, 5.5vw, 4.25rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--gz-ivory);
	margin: 0 0 var(--gz-space-xl);
	letter-spacing: -0.02em;
}

.gz-slide__headline em {
	font-style: normal;
	color: var(--gz-gold);
}

/* Description */
.gz-slide__desc {
	font-family: var(--gz-font-body);
	font-size: clamp(0.9375rem, 1.5vw, 1.0625rem);
	font-weight: 400;
	line-height: 1.7;
	color: rgba(250, 247, 240, 0.8);
	margin: 0 0 var(--gz-space-2xl);
	max-width: 520px;
}

/* CTA buttons */
.gz-slide__actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--gz-space-lg);
}

.gz-slide__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--gz-font-body);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	border-radius: 4px;
	padding: 14px 28px;
	min-height: 50px;
	transition: background 0.25s ease, color 0.25s ease, transform 0.2s ease, box-shadow 0.25s ease;
}

.gz-slide__cta--primary {
	background: var(--gz-gold);
	color: var(--gz-deep-indigo);
}

.gz-slide__cta--primary svg {
	transition: transform 0.2s ease;
}

.gz-slide__cta--primary:hover {
	background: #fff;
	color: var(--gz-deep-indigo);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(250, 208, 44, 0.35);
	text-decoration: none;
}

.gz-slide__cta--primary:hover svg {
	transform: translateX(4px);
}

.gz-slide__cta--outline {
	background: transparent;
	color: var(--gz-ivory);
	border: 2px solid rgba(250, 247, 240, 0.35);
}

.gz-slide__cta--outline:hover {
	background: rgba(250, 247, 240, 0.1);
	border-color: var(--gz-ivory);
	color: var(--gz-ivory);
	transform: translateY(-2px);
	text-decoration: none;
}

.gz-slide__cta:visited {
	color: inherit;
}

/* ── Progress bar ── */
.gz-slider__progress {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: rgba(250, 247, 240, 0.1);
	z-index: 10;
}

.gz-slider__progress-bar {
	height: 100%;
	width: 0;
	background: var(--gz-gold);
	border-radius: 0 2px 2px 0;
}

/* ── Navigation bar ── */
.gz-slider__nav {
	position: absolute;
	bottom: 36px;
	left: 0;
	right: 0;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--gz-space-xl);
	padding: 0 var(--gz-space-2xl);
}

/* Arrow buttons */
.gz-slider__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: rgba(250, 247, 240, 0.08);
	border: 1px solid rgba(250, 247, 240, 0.2);
	border-radius: 50%;
	color: var(--gz-ivory);
	cursor: pointer;
	min-height: unset;
	padding: 0;
	box-shadow: none;
	transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
	backdrop-filter: blur(4px);
}

.gz-slider__arrow:hover {
	background: var(--gz-gold);
	border-color: var(--gz-gold);
	color: var(--gz-deep-indigo);
	transform: none;
	box-shadow: none;
}

/* Dots */
.gz-slider__dots {
	display: flex;
	align-items: center;
	gap: 10px;
}

.gz-slider__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(250, 247, 240, 0.3);
	border: none;
	padding: 0;
	min-height: unset;
	cursor: pointer;
	box-shadow: none;
	transition: background 0.25s ease, width 0.3s ease, border-radius 0.3s ease;
}

.gz-slider__dot--active {
	width: 28px;
	border-radius: 4px;
	background: var(--gz-gold);
}

.gz-slider__dot:hover:not(.gz-slider__dot--active) {
	background: rgba(250, 247, 240, 0.6);
	transform: none;
	box-shadow: none;
}

/* Counter */
.gz-slider__counter {
	display: flex;
	align-items: baseline;
	gap: 4px;
	font-family: var(--gz-font-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	color: rgba(250, 247, 240, 0.5);
	min-width: 40px;
	justify-content: center;
}

.gz-slider__counter-current {
	font-size: 1rem;
	color: var(--gz-gold);
	font-weight: 700;
}

.gz-slider__counter-sep {
	font-size: 0.625rem;
}

/* ── Scroll hint ── */
.gz-slider__scroll-hint {
	position: absolute;
	right: var(--gz-space-2xl);
	bottom: 100px;
	z-index: 10;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	opacity: 0.45;
}

.gz-slider__scroll-hint span {
	font-family: var(--gz-font-body);
	font-size: 0.6rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--gz-ivory);
	writing-mode: vertical-rl;
}

.gz-slider__scroll-line {
	width: 1px;
	height: 48px;
	background: linear-gradient(to bottom, var(--gz-gold), transparent);
	animation: gz-scroll-pulse 2s ease-in-out infinite;
}

@keyframes gz-scroll-pulse {
	0%, 100% { opacity: 0.4; transform: scaleY(1); }
	50%       { opacity: 1;   transform: scaleY(0.7) translateY(8px); }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
	.gz-slide,
	.gz-slide__eyebrow,
	.gz-slide__divider,
	.gz-slide__headline,
	.gz-slide__desc,
	.gz-slide__actions,
	.gz-slide__gem {
		transition: opacity 0.3s ease !important;
		transform: none !important;
		animation: none !important;
	}

	.gz-slider__scroll-line {
		animation: none;
	}
}

/* ── Responsive ── */
@media screen and (max-width: 1023px) {
	.gz-slide__content-inner {
		margin-left: var(--gz-space-2xl);
		max-width: 580px;
	}

	.gz-slide__gem {
		right: 3%;
		opacity: 0.5;
	}
}

@media screen and (max-width: 767px) {
	.gz-hero-slider {
		min-height: 100svh;
	}

	.gz-slide__content-inner {
		margin-left: 0;
		padding: 0 var(--gz-space-lg);
		max-width: 100%;
	}

	.gz-slide__gem {
		display: none;
	}

	.gz-slide__number-bg {
		right: 0;
		font-size: 40vw;
	}

	.gz-slider__scroll-hint {
		display: none;
	}

	.gz-slider__nav {
		gap: var(--gz-space-lg);
		bottom: 28px;
	}

	.gz-slider__counter {
		display: none;
	}

	.gz-slide__actions {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--gz-space-md);
	}

	.gz-slide__cta {
		width: 100%;
		justify-content: center;
		padding: 14px 20px;
	}
}

/*--------------------------------------------------------------
# Blog Widget & Cards
--------------------------------------------------------------*/

/* ── Section wrapper ── */
.gz-blog { width: 100%; }
.gz-blog--bg-ivory  { background: var(--gz-ivory); }
.gz-blog--bg-white  { background: #fff; }
.gz-blog--bg-indigo { background: var(--gz-deep-indigo); }
.gz-blog--bg-indigo .gz-blog__title,
.gz-blog--bg-indigo .gz-blog__subtitle { color: var(--gz-ivory); }

.gz-blog__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 60px 40px;
}

.gz-blog__header {
	text-align: center;
	margin-bottom: 48px;
}

.gz-blog__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 12px;
	letter-spacing: -0.02em;
}

.gz-blog__subtitle {
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: rgba(31,12,49,.65);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.6;
}

/* ── Grid ── */
.gz-blog__grid {
	display: grid;
	gap: 28px;
}
.gz-blog__grid--cols-1 { grid-template-columns: 1fr; }
.gz-blog__grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.gz-blog__grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.gz-blog__grid--cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ── Card base ── */
.gz-blog-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 8px;
	overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease;
}

.gz-blog-card--elevated {
	box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.gz-blog-card--elevated:hover {
	transform: translateY(-5px);
	box-shadow: 0 12px 32px rgba(31,12,49,.12);
}

.gz-blog-card--bordered {
	border: 1px solid rgba(31,12,49,.1);
	border-top: 3px solid var(--gz-teal);
}
.gz-blog-card--bordered:hover {
	border-top-color: var(--gz-gold);
	transform: translateY(-4px);
}

.gz-blog-card--minimal {
	background: transparent;
	border-bottom: 1px solid rgba(31,12,49,.12);
	border-radius: 0;
	padding-bottom: 24px;
}

/* ── Featured image ── */
.gz-blog-card__image-link { display: block; }
.gz-blog-card__image-wrap {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 9;
	background: var(--gz-deep-indigo);
}
.gz-blog-card__image {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .45s ease;
}
.gz-blog-card:hover .gz-blog-card__image { transform: scale(1.06); }
.gz-blog-card__image-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(to bottom, transparent 50%, rgba(31,12,49,.35) 100%);
	pointer-events: none;
}

/* ── Card body ── */
.gz-blog-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 22px 24px 20px;
	gap: 10px;
}

/* ── Category badges ── */
.gz-blog-card__cats { display: flex; flex-wrap: wrap; gap: 6px; }
.gz-blog-card__cat {
	font-family: var(--gz-font-body);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--gz-teal);
	background: rgba(0,104,122,.08);
	padding: 3px 10px;
	border-radius: 20px;
	text-decoration: none;
	transition: background .2s ease, color .2s ease;
}
.gz-blog-card__cat:hover { background: var(--gz-teal); color: #fff; text-decoration: none; }

/* ── Title ── */
.gz-blog-card__title {
	font-family: var(--gz-font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	line-height: 1.3;
	margin: 0;
}
.gz-blog-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color .2s ease;
}
.gz-blog-card__title a:hover { color: var(--gz-purple); text-decoration: none; }

/* ── Excerpt ── */
.gz-blog-card__excerpt {
	font-family: var(--gz-font-body);
	font-size: .875rem;
	color: rgba(31,12,49,.65);
	line-height: 1.6;
	margin: 0;
	flex: 1;
}

/* ── Footer: meta + read more ── */
.gz-blog-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: auto;
	padding-top: 14px;
	border-top: 1px solid rgba(31,12,49,.08);
}
.gz-blog-card__meta {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.gz-blog-card__avatar {
	width: 24px; height: 24px;
	border-radius: 50%;
	object-fit: cover;
}
.gz-blog-card__author,
.gz-blog-card__date,
.gz-blog-card__read-time {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	color: rgba(31,12,49,.5);
}
.gz-blog-card__author { color: rgba(31,12,49,.7); font-weight: 600; }
.gz-blog-card__date::before,
.gz-blog-card__read-time::before { content: '·'; margin-right: 6px; opacity: .4; }

.gz-blog-card__read-more {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: var(--gz-font-body);
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--gz-teal);
	text-decoration: none;
	transition: color .2s ease, gap .2s ease;
}
.gz-blog-card__read-more:hover { color: var(--gz-purple); gap: 8px; text-decoration: none; }

/* ── Section CTA ── */
.gz-blog__cta { text-align: center; margin-top: 40px; }
.gz-blog__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	text-decoration: none;
	color: var(--gz-deep-indigo);
	background: var(--gz-gold);
	padding: 14px 32px;
	border-radius: 4px;
	transition: background .2s ease, transform .15s ease;
}
.gz-blog__cta-btn:hover { background: var(--gz-gold-dark); transform: translateY(-2px); text-decoration: none; }

/* ── Responsive grid ── */
@media screen and (max-width: 1023px) {
	.gz-blog__grid--cols-4,
	.gz-blog__grid--cols-3 { grid-template-columns: repeat(2, 1fr); }
}
@media screen and (max-width: 640px) {
	.gz-blog__grid--cols-4,
	.gz-blog__grid--cols-3,
	.gz-blog__grid--cols-2 { grid-template-columns: 1fr; }
	.gz-blog__inner { padding: 40px 20px; }
}

/*--------------------------------------------------------------
# Single Post
--------------------------------------------------------------*/

/* ── Hero ── */
.gz-single__hero {
	position: relative;
	min-height: 480px;
	display: flex;
	align-items: flex-end;
	background: var(--gz-deep-indigo);
	background-size: cover;
	background-position: center;
	padding-top: 80px;
}
.gz-single__hero-overlay {
	position: absolute; inset: 0;
	background: linear-gradient(to bottom, rgba(31,12,49,.3) 0%, rgba(31,12,49,.92) 100%);
}
.gz-single__hero-content {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 860px;
	margin: 0 auto;
	padding: 40px 40px 56px;
}

/* Breadcrumb */
.gz-single__breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--gz-font-body);
	font-size: .75rem;
	color: rgba(250,247,240,.55);
	margin-bottom: 16px;
	flex-wrap: wrap;
}
.gz-single__breadcrumb a { color: rgba(250,247,240,.7); text-decoration: none; }
.gz-single__breadcrumb a:hover { color: var(--gz-gold); text-decoration: none; }

/* Category badges */
.gz-single__cats { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.gz-single__cat {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--gz-deep-indigo);
	background: var(--gz-gold);
	padding: 4px 12px;
	border-radius: 20px;
	text-decoration: none;
}
.gz-single__cat:hover { background: #fff; text-decoration: none; }

/* Title */
.gz-single__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: 700;
	color: var(--gz-ivory);
	line-height: 1.15;
	letter-spacing: -.02em;
	margin: 0 0 24px;
}

/* Meta */
.gz-single__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}
.gz-single__author-info {
	display: flex;
	align-items: center;
	gap: 12px;
}
.gz-single__avatar {
	width: 44px; height: 44px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--gz-gold);
}
.gz-single__author-name {
	display: block;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	color: var(--gz-ivory);
}
.gz-single__author-label {
	display: block;
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	color: rgba(250,247,240,.5);
	text-transform: uppercase;
	letter-spacing: .06em;
}
.gz-single__meta-right {
	display: flex;
	align-items: center;
	gap: 16px;
}
.gz-single__date,
.gz-single__read-time {
	display: flex;
	align-items: center;
	gap: 5px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	color: rgba(250,247,240,.6);
}

/* ── Layout ── */
.gz-single__layout {
	background: var(--gz-ivory);
	padding: 60px 0;
}
.gz-single__container {
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 40px;
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 60px;
	align-items: start;
}
.gz-single__container--narrow {
	max-width: 860px;
	display: block;
}

/* ── Prose (content) ── */
.gz-single__prose {
	font-family: var(--gz-font-body);
	font-size: 1.0625rem;
	line-height: 1.8;
	color: rgba(31,12,49,.85);
}
.gz-single__prose h2 {
	font-family: var(--gz-font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 2em 0 .6em;
}
.gz-single__prose h3 {
	font-family: var(--gz-font-heading);
	font-size: 1.2rem;
	color: var(--gz-purple);
	margin: 1.6em 0 .5em;
}
.gz-single__prose p { margin-bottom: 1.4em; }
.gz-single__prose ul, .gz-single__prose ol {
	padding-left: 1.5em;
	margin-bottom: 1.4em;
}
.gz-single__prose li { margin-bottom: .4em; }
.gz-single__prose blockquote {
	border-left: 4px solid var(--gz-gold);
	padding: 16px 24px;
	margin: 2em 0;
	background: rgba(250,208,44,.06);
	border-radius: 0 6px 6px 0;
	font-family: var(--gz-font-heading);
	font-style: italic;
	font-size: 1.125rem;
	color: var(--gz-purple);
}
.gz-single__prose a { color: var(--gz-teal); }
.gz-single__prose a:hover { color: var(--gz-purple); }
.gz-single__prose strong { color: var(--gz-deep-indigo); }
.gz-single__prose img { border-radius: 6px; max-width: 100%; }

/* ── Tags ── */
.gz-single__tags {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-top: 40px;
	padding-top: 24px;
	border-top: 1px solid rgba(31,12,49,.1);
}
.gz-single__tags-label {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: rgba(31,12,49,.5);
}
.gz-single__tag {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	color: var(--gz-teal);
	background: rgba(0,104,122,.08);
	padding: 3px 10px;
	border-radius: 20px;
	text-decoration: none;
	transition: background .2s ease;
}
.gz-single__tag:hover { background: var(--gz-teal); color: #fff; text-decoration: none; }

/* ── Share ── */
.gz-single__share {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 32px;
	flex-wrap: wrap;
}
.gz-single__share-label {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: rgba(31,12,49,.5);
}
.gz-single__share-links { display: flex; gap: 8px; }
.gz-single__share-btn {
	display: flex; align-items: center; justify-content: center;
	width: 36px; height: 36px;
	border-radius: 50%;
	text-decoration: none;
	transition: background .2s ease, color .2s ease;
	background: rgba(31,12,49,.08);
	color: var(--gz-deep-indigo);
}
.gz-single__share-btn:hover { text-decoration: none; }
.gz-single__share-btn--x:hover        { background: #000; color: #fff; }
.gz-single__share-btn--linkedin:hover { background: #0077b5; color: #fff; }
.gz-single__share-btn--facebook:hover { background: #1877f2; color: #fff; }

/* ── Post navigation ── */
.gz-single__post-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid rgba(31,12,49,.1);
}
.gz-single__nav-item {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 16px 20px;
	background: #fff;
	border-radius: 6px;
	border: 1px solid rgba(31,12,49,.1);
	text-decoration: none;
	transition: border-color .2s ease, box-shadow .2s ease;
}
.gz-single__nav-item:hover { border-color: var(--gz-teal); box-shadow: 0 4px 12px rgba(0,104,122,.1); text-decoration: none; }
.gz-single__nav-item--next { text-align: right; }
.gz-single__nav-label {
	display: flex;
	align-items: center;
	gap: 4px;
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--gz-teal);
}
.gz-single__nav-item--next .gz-single__nav-label { justify-content: flex-end; }
.gz-single__nav-title {
	font-family: var(--gz-font-heading);
	font-size: .9375rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	line-height: 1.3;
}

/* ── Sidebar ── */
.gz-single__sidebar { display: flex; flex-direction: column; gap: 24px; }
.gz-sidebar-card {
	background: #fff;
	border-radius: 8px;
	padding: 24px;
	box-shadow: 0 2px 10px rgba(0,0,0,.06);
}
.gz-sidebar-card__heading {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: rgba(31,12,49,.45);
	margin: 0 0 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(31,12,49,.08);
}

/* Author card */
.gz-author-card { text-align: center; }
.gz-author-card__avatar-wrap { margin-bottom: 12px; }
.gz-author-card__avatar {
	width: 80px; height: 80px;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid var(--gz-gold);
}
.gz-author-card__name {
	font-family: var(--gz-font-heading);
	font-size: 1rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 8px;
}
.gz-author-card__bio {
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	color: rgba(31,12,49,.65);
	line-height: 1.6;
	margin: 0;
}

/* Related posts */
.gz-related-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.gz-related-item { display: flex; gap: 12px; align-items: flex-start; }
.gz-related-item__thumb {
	width: 60px; height: 60px;
	object-fit: cover;
	border-radius: 4px;
	flex-shrink: 0;
}
.gz-related-item__text { display: flex; flex-direction: column; gap: 4px; }
.gz-related-item__title {
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 600;
	color: var(--gz-deep-indigo);
	text-decoration: none;
	line-height: 1.4;
}
.gz-related-item__title:hover { color: var(--gz-teal); text-decoration: none; }
.gz-related-item__date { font-size: .6875rem; color: rgba(31,12,49,.45); }

/* Category list */
.gz-cat-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.gz-cat-list__link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 0;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	color: var(--gz-deep-indigo);
	text-decoration: none;
	border-bottom: 1px solid rgba(31,12,49,.06);
	transition: color .2s ease;
}
.gz-cat-list__link:hover { color: var(--gz-teal); text-decoration: none; }
.gz-cat-list__count {
	font-size: .6875rem;
	font-weight: 700;
	background: rgba(31,12,49,.08);
	padding: 2px 8px;
	border-radius: 20px;
}

/* ── Comments wrap ── */
.gz-single__comments-wrap {
	background: #fff;
	padding: 60px 0;
	border-top: 1px solid rgba(31,12,49,.1);
}

/* ── Single responsive ── */
@media screen and (max-width: 1023px) {
	.gz-single__container { grid-template-columns: 1fr; gap: 40px; }
	.gz-single__sidebar { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
}
@media screen and (max-width: 767px) {
	.gz-single__hero-content { padding: 24px 20px 40px; }
	.gz-single__container { padding: 0 20px; }
	.gz-single__post-nav { grid-template-columns: 1fr; }
	.gz-single__sidebar { grid-template-columns: 1fr; }
	.gz-single__layout { padding: 40px 0; }
}

/*--------------------------------------------------------------
# Archive Page
--------------------------------------------------------------*/

.gz-archive { background: var(--gz-ivory); }

/* Hero header */
.gz-archive__hero {
	background: var(--gz-deep-indigo);
	padding: 100px 40px 60px;
}
.gz-archive__hero-inner {
	max-width: 860px;
	margin: 0 auto;
}
.gz-archive__hero-eyebrow {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--gz-teal);
	margin: 0 0 10px;
}
.gz-archive__hero-title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 12px;
	letter-spacing: -.02em;
}
.gz-archive__hero-desc {
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: rgba(250,247,240,.65);
	margin: 0;
	line-height: 1.6;
}

/* Filter pills */
.gz-archive__filter {
	background: #fff;
	border-bottom: 1px solid rgba(31,12,49,.08);
	position: sticky;
	top: 80px;
	z-index: 100;
}
.gz-archive__filter-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 14px 40px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.gz-filter-pill {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: rgba(31,12,49,.6);
	background: transparent;
	border: 1px solid rgba(31,12,49,.15);
	padding: 6px 14px;
	border-radius: 20px;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.gz-filter-pill:hover { border-color: var(--gz-teal); color: var(--gz-teal); text-decoration: none; }
.gz-filter-pill--active { background: var(--gz-deep-indigo); color: var(--gz-ivory); border-color: var(--gz-deep-indigo); }
.gz-filter-pill--active:hover { color: var(--gz-gold); text-decoration: none; }
.gz-filter-pill__count {
	background: rgba(250,247,240,.2);
	padding: 1px 6px;
	border-radius: 10px;
	font-size: .625rem;
}
.gz-filter-pill--active .gz-filter-pill__count { background: rgba(255,255,255,.15); }

/* Main area */
.gz-archive__main { padding: 60px 0; }
.gz-archive__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
}

/* Empty state */
.gz-archive__empty {
	text-align: center;
	padding: 80px 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
}
.gz-archive__empty p {
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: rgba(31,12,49,.55);
}

/* Pagination */
.gz-archive__pagination { margin-top: 48px; display: flex; justify-content: center; }
.gz-archive__pagination .page-numbers {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 6px;
	flex-wrap: wrap;
	align-items: center;
}
.gz-archive__pagination .page-numbers li a,
.gz-archive__pagination .page-numbers li span {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 8px 16px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 600;
	border-radius: 4px;
	text-decoration: none;
	color: var(--gz-deep-indigo);
	background: #fff;
	border: 1px solid rgba(31,12,49,.12);
	transition: background .2s ease, border-color .2s ease;
}
.gz-archive__pagination .page-numbers li a:hover { background: var(--gz-ivory); border-color: var(--gz-teal); text-decoration: none; }
.gz-archive__pagination .page-numbers li span.current { background: var(--gz-deep-indigo); color: var(--gz-ivory); border-color: var(--gz-deep-indigo); }

/* Archive responsive */
@media screen and (max-width: 1023px) {
	.gz-archive__hero { padding: 100px 24px 48px; }
	.gz-archive__filter-inner,
	.gz-archive__inner { padding-left: 24px; padding-right: 24px; }
}
@media screen and (max-width: 640px) {
	.gz-archive__hero { padding: 100px 20px 40px; }
	.gz-archive__filter-inner,
	.gz-archive__inner { padding-left: 16px; padding-right: 16px; }
	.gz-archive__main { padding: 40px 0; }
}

/*--------------------------------------------------------------
# Blog Home Page (home.php / page-blog.php)
--------------------------------------------------------------*/

/* ── Page wrapper ── */
.gz-blog-home { background: var(--gz-ivory); }

/* ── Hero ── */
.gz-blog-home__hero {
	background: var(--gz-deep-indigo);
	padding: 120px 40px 64px;
	position: relative;
	overflow: hidden;
}
.gz-blog-home__hero::before {
	content: '';
	position: absolute;
	top: -40%;
	right: -10%;
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(92,58,142,.18) 0%, transparent 70%);
	pointer-events: none;
}
.gz-blog-home__hero-inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
	position: relative;
}
.gz-blog-home__eyebrow {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--gz-teal);
	margin: 0 0 14px;
}
.gz-blog-home__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2.25rem, 5vw, 3.75rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 18px;
	letter-spacing: -.025em;
	line-height: 1.1;
}
.gz-blog-home__subtitle {
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: rgba(250,247,240,.6);
	line-height: 1.7;
	margin: 0;
	max-width: 580px;
	margin-inline: auto;
}

/* ── Main & inner ── */
.gz-blog-home__main { padding: 56px 0 80px; }
.gz-blog-home__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
}

/* ── Section head (between featured + grid) ── */
.gz-blog-home__section-head {
	display: flex;
	align-items: center;
	gap: 20px;
	margin: 56px 0 32px;
}
.gz-blog-home__section-title {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: rgba(31,12,49,.4);
	white-space: nowrap;
	margin: 0;
}
.gz-blog-home__section-line {
	flex: 1;
	height: 1px;
	background: rgba(31,12,49,.1);
}

/* ── Featured post card ── */
.gz-blog-featured {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 460px;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 8px 40px rgba(31,12,49,.14);
	transition: box-shadow .3s ease, transform .3s ease;
}
.gz-blog-featured:hover {
	box-shadow: 0 16px 56px rgba(31,12,49,.2);
	transform: translateY(-3px);
}

/* Image side */
.gz-blog-featured__image-side {
	position: relative;
	overflow: hidden;
	display: block;
}
.gz-blog-featured__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .6s ease;
}
.gz-blog-featured:hover .gz-blog-featured__image { transform: scale(1.05); }
.gz-blog-featured__image-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, transparent 60%, rgba(31,12,49,.3));
	pointer-events: none;
}

/* Content side */
.gz-blog-featured__content {
	background: var(--gz-deep-indigo);
	padding: 48px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 20px;
}
.gz-blog-featured__content--full {
	grid-column: 1 / -1;
	padding: 64px;
}

/* Top meta row */
.gz-blog-featured__meta-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
}
.gz-blog-featured__cats { display: flex; gap: 6px; }
.gz-blog-featured__cat {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--gz-deep-indigo);
	background: var(--gz-gold);
	padding: 4px 12px;
	border-radius: 20px;
	text-decoration: none;
	transition: background .2s ease;
}
.gz-blog-featured__cat:hover { background: #fff; text-decoration: none; }
.gz-blog-featured__label {
	font-family: var(--gz-font-body);
	font-size: .625rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: rgba(250,247,240,.35);
}

/* Title */
.gz-blog-featured__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.375rem, 2.5vw, 2rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -.015em;
	margin: 0;
	flex: 1;
}
.gz-blog-featured__title a {
	color: var(--gz-ivory);
	text-decoration: none;
	transition: color .2s ease;
}
.gz-blog-featured__title a:hover { color: var(--gz-gold); text-decoration: none; }

/* Excerpt */
.gz-blog-featured__excerpt {
	font-family: var(--gz-font-body);
	font-size: .9375rem;
	line-height: 1.65;
	color: rgba(250,247,240,.65);
	margin: 0;
}

/* Footer */
.gz-blog-featured__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	padding-top: 20px;
	border-top: 1px solid rgba(250,247,240,.1);
}
.gz-blog-featured__author {
	display: flex;
	align-items: center;
	gap: 12px;
}
.gz-blog-featured__avatar {
	width: 36px; height: 36px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--gz-gold);
}
.gz-blog-featured__author-name {
	display: block;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	color: var(--gz-ivory);
}
.gz-blog-featured__author-meta {
	display: block;
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	color: rgba(250,247,240,.45);
}
.gz-blog-featured__cta {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--gz-deep-indigo);
	background: var(--gz-gold);
	padding: 11px 22px;
	border-radius: 4px;
	text-decoration: none;
	transition: background .2s ease, transform .15s ease;
}
.gz-blog-featured__cta:hover { background: #fff; transform: translateY(-1px); text-decoration: none; }

/* ── Empty state ── */
.gz-blog-home__empty {
	text-align: center;
	padding: 80px 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
}
.gz-blog-home__empty-icon { color: rgba(31,12,49,.2); }
.gz-blog-home__empty-title {
	font-family: var(--gz-font-heading);
	font-size: 1.5rem;
	color: var(--gz-deep-indigo);
	margin: 0;
}
.gz-blog-home__empty-text {
	font-family: var(--gz-font-body);
	font-size: .9375rem;
	color: rgba(31,12,49,.55);
	max-width: 420px;
	line-height: 1.6;
	margin: 0;
}

/* ── Responsive ── */
@media screen and (max-width: 1023px) {
	.gz-blog-featured { grid-template-columns: 1fr; min-height: auto; }
	.gz-blog-featured__image-side { aspect-ratio: 16 / 7; }
	.gz-blog-featured__content { padding: 36px; }
	.gz-blog-home__hero { padding: 110px 24px 56px; }
	.gz-blog-home__inner { padding: 0 24px; }
}
@media screen and (max-width: 640px) {
	.gz-blog-featured__content { padding: 24px 20px; }
	.gz-blog-home__inner { padding: 0 16px; }
	.gz-blog-home__hero { padding: 100px 16px 48px; }
	.gz-blog-home__main { padding: 40px 0 60px; }
}

/*--------------------------------------------------------------
# 404 Page
--------------------------------------------------------------*/

.gz-404 { background: var(--gz-ivory); }

/* ── Hero ── */
.gz-404__hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gz-deep-indigo);
	overflow: hidden;
	padding: 80px 40px 80px;
	margin-top: -80px;
}

/* Radial glow */
.gz-404__hero::before {
	content: '';
	position: absolute;
	top: 20%;
	left: 50%;
	transform: translateX(-50%);
	width: 700px;
	height: 700px;
	background: radial-gradient(circle, rgba(92,58,142,.2) 0%, transparent 65%);
	pointer-events: none;
}

/* Big background 404 */
.gz-404__bg-number {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-family: var(--gz-font-heading);
	font-size: clamp(18rem, 40vw, 36rem);
	font-weight: 700;
	line-height: 1;
	color: rgba(250,247,240,.025);
	letter-spacing: -.05em;
	pointer-events: none;
	user-select: none;
	white-space: nowrap;
}

/* Gem decoration */
.gz-404__gem {
	position: absolute;
	right: 6%;
	top: 50%;
	transform: translateY(-50%);
	width: clamp(180px, 20vw, 300px);
	color: var(--gz-gold);
	pointer-events: none;
	opacity: .5;
	animation: gz-404-gem-float 8s ease-in-out infinite;
}

@keyframes gz-404-gem-float {
	0%, 100% { transform: translateY(-50%) rotate(0deg); }
	33%       { transform: translateY(calc(-50% - 16px)) rotate(3deg); }
	66%       { transform: translateY(calc(-50% + 10px)) rotate(-2deg); }
}

/* Hero content */
.gz-404__hero-content {
	position: relative;
	z-index: 2;
	max-width: 600px;
	width: 100%;
	padding-top: 40px;
}

/* Eyebrow */
.gz-404__eyebrow {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--gz-teal);
	margin: 0 0 16px;
}

/* Gold divider */
.gz-404__divider {
	width: 48px;
	height: 3px;
	background: var(--gz-gold);
	border-radius: 2px;
	margin: 0 0 24px;
}

/* Title */
.gz-404__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	font-weight: 700;
	color: var(--gz-ivory);
	line-height: 1.1;
	letter-spacing: -.025em;
	margin: 0 0 20px;
}
.gz-404__title em {
	font-style: normal;
	color: var(--gz-gold);
}

/* Description */
.gz-404__desc {
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: rgba(250,247,240,.62);
	line-height: 1.7;
	margin: 0 0 36px;
	max-width: 480px;
}

/* Search */
.gz-404__search { margin-bottom: 32px; }
.gz-404__search-wrap {
	display: flex;
	align-items: center;
	background: rgba(250,247,240,.08);
	border: 1px solid rgba(250,247,240,.15);
	border-radius: 50px;
	overflow: hidden;
	transition: border-color .2s ease, background .2s ease;
	max-width: 480px;
}
.gz-404__search-wrap:focus-within {
	border-color: var(--gz-gold);
	background: rgba(250,247,240,.12);
}
.gz-404__search-input {
	flex: 1;
	background: transparent;
	border: none;
	padding: 14px 20px;
	font-family: var(--gz-font-body);
	font-size: .9375rem;
	color: var(--gz-ivory);
	outline: none;
	width: auto;
}
.gz-404__search-input::placeholder { color: rgba(250,247,240,.35); }
.gz-404__search-btn {
	background: var(--gz-gold);
	border: none;
	color: var(--gz-deep-indigo);
	padding: 14px 20px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: unset;
	width: auto;
	border-radius: 0;
	box-shadow: none;
	transition: background .2s ease;
}
.gz-404__search-btn:hover {
	background: var(--gz-gold-dark);
	transform: none;
	box-shadow: none;
}

/* Quick links */
.gz-404__links {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}
.gz-404__links-label {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	font-weight: 600;
	color: rgba(250,247,240,.35);
	text-transform: uppercase;
	letter-spacing: .08em;
	margin-right: 4px;
}
.gz-404__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 600;
	color: rgba(250,247,240,.65);
	background: rgba(250,247,240,.07);
	border: 1px solid rgba(250,247,240,.12);
	padding: 7px 14px;
	border-radius: 20px;
	text-decoration: none;
	transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.gz-404__link:hover {
	background: var(--gz-gold);
	color: var(--gz-deep-indigo);
	border-color: var(--gz-gold);
	text-decoration: none;
}
.gz-404__link:visited { color: rgba(250,247,240,.65); }
.gz-404__link:hover:visited { color: var(--gz-deep-indigo); }

/* ── Recent articles ── */
.gz-404__recent {
	background: var(--gz-ivory);
	padding: 72px 0 80px;
}
.gz-404__recent-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
}
.gz-404__recent-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 36px;
	flex-wrap: wrap;
	gap: 12px;
}
.gz-404__recent-title {
	font-family: var(--gz-font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0;
}
.gz-404__recent-all {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--gz-teal);
	text-decoration: none;
	transition: color .2s ease, gap .2s ease;
}
.gz-404__recent-all:hover { color: var(--gz-purple); gap: 10px; text-decoration: none; }

/* ── Responsive ── */
@media screen and (max-width: 1023px) {
	.gz-404__gem { display: none; }
	.gz-404__hero { padding: 100px 32px 80px; }
	.gz-404__recent-inner { padding: 0 24px; }
}
@media screen and (max-width: 640px) {
	.gz-404__hero { padding: 100px 20px 72px; align-items: flex-start; }
	.gz-404__bg-number { font-size: 50vw; }
	.gz-404__recent-inner { padding: 0 16px; }
	.gz-404__recent { padding: 48px 0 60px; }
	.gz-404__links { gap: 6px; }
}

/*--------------------------------------------------------------
# Search Page
--------------------------------------------------------------*/

.gz-search-page { background: var(--gz-ivory); }

/* Hero */
.gz-search__hero {
	background: var(--gz-deep-indigo);
	padding: calc(80px + 56px) 40px 56px;
	margin-top: -80px;
}
.gz-search__hero-inner { max-width: 760px; margin: 0 auto; }

.gz-search__eyebrow {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--gz-teal);
	margin: 0 0 12px;
}
.gz-search__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 8px;
	letter-spacing: -.02em;
	line-height: 1.15;
}
.gz-search__title em { font-style: normal; color: var(--gz-gold); }
.gz-search__count {
	font-family: var(--gz-font-body);
	font-size: .875rem;
	color: rgba(250,247,240,.5);
	margin: 0 0 28px;
}

/* Search form */
.gz-search__form { max-width: 600px; }
.gz-search__form-wrap {
	display: flex;
	background: rgba(250,247,240,.1);
	border: 1px solid rgba(250,247,240,.18);
	border-radius: 6px;
	overflow: hidden;
	transition: border-color .2s ease;
}
.gz-search__form-wrap:focus-within { border-color: var(--gz-gold); }
.gz-search__input {
	flex: 1;
	background: transparent;
	border: none;
	padding: 14px 18px;
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: var(--gz-ivory);
	outline: none;
	width: auto;
}
.gz-search__input::placeholder { color: rgba(250,247,240,.35); }
.gz-search__submit {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	background: var(--gz-gold);
	border: none;
	color: var(--gz-deep-indigo);
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	padding: 14px 22px;
	cursor: pointer;
	min-height: unset;
	width: auto;
	border-radius: 0;
	box-shadow: none;
	white-space: nowrap;
	transition: background .2s ease;
}
.gz-search__submit:hover { background: var(--gz-gold-dark); transform: none; box-shadow: none; }

/* Main */
.gz-search__main { padding: 48px 0 80px; }
.gz-search__inner { max-width: 900px; margin: 0 auto; padding: 0 40px; }

/* Result items */
.gz-search__results { display: flex; flex-direction: column; gap: 2px; }

.gz-search-result {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	background: #fff;
	border: 1px solid rgba(31,12,49,.07);
	border-radius: 8px;
	padding: 22px 20px;
	text-decoration: none;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
	position: relative;
}
.gz-search-result:hover {
	border-color: var(--gz-teal);
	box-shadow: 0 4px 20px rgba(0,104,122,.1);
	transform: translateX(4px);
}

/* Thumbnail */
.gz-search-result__thumb-link { flex-shrink: 0; }
.gz-search-result__thumb-wrap {
	width: 88px; height: 72px;
	border-radius: 6px;
	overflow: hidden;
	background: var(--gz-deep-indigo);
}
.gz-search-result__thumb { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Body */
.gz-search-result__body { flex: 1; min-width: 0; }

.gz-search-result__badges {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 8px;
	flex-wrap: wrap;
}
.gz-search-result__type {
	font-family: var(--gz-font-body);
	font-size: .625rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding: 2px 8px;
	border-radius: 20px;
}
.gz-search-result__type--post { background: rgba(0,104,122,.1); color: var(--gz-teal); }
.gz-search-result__type--page { background: rgba(92,58,142,.1); color: var(--gz-purple); }
.gz-search-result__cat {
	font-family: var(--gz-font-body);
	font-size: .625rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--gz-teal);
	text-decoration: none;
}
.gz-search-result__cat:hover { color: var(--gz-purple); text-decoration: none; }

.gz-search-result__title {
	font-family: var(--gz-font-heading);
	font-size: 1.0625rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 6px;
	line-height: 1.3;
}
.gz-search-result__title a { color: inherit; text-decoration: none; }
.gz-search-result__title a:hover { color: var(--gz-purple); text-decoration: none; }
.gz-search-result__title mark,
.gz-search-result__excerpt mark {
	background: rgba(250,208,44,.35);
	color: var(--gz-deep-indigo);
	padding: 0 2px;
	border-radius: 2px;
}

.gz-search-result__excerpt {
	font-family: var(--gz-font-body);
	font-size: .875rem;
	color: rgba(31,12,49,.6);
	line-height: 1.6;
	margin: 0 0 10px;
}

.gz-search-result__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	color: rgba(31,12,49,.35);
}
.gz-search-result__url {
	color: var(--gz-teal);
	opacity: .7;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 260px;
}
.gz-search-result__date::before,
.gz-search-result__read-time::before { content: '·'; margin-right: 6px; }

/* Arrow */
.gz-search-result__arrow {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	color: rgba(31,12,49,.2);
	padding-top: 2px;
	text-decoration: none;
	transition: color .2s ease, transform .2s ease;
}
.gz-search-result:hover .gz-search-result__arrow { color: var(--gz-teal); transform: translateX(3px); }

/* No results */
.gz-search__no-results {
	text-align: center;
	padding: 60px 20px 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
}
.gz-search__no-results-icon { color: rgba(31,12,49,.15); }
.gz-search__no-results-title {
	font-family: var(--gz-font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0;
}
.gz-search__no-results-text {
	font-family: var(--gz-font-body);
	font-size: .9375rem;
	color: rgba(31,12,49,.55);
	max-width: 420px;
	line-height: 1.6;
	margin: 0;
}
.gz-search__suggestions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 4px;
}
.gz-search__suggestion-link {
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 600;
	color: var(--gz-deep-indigo);
	background: #fff;
	border: 1px solid rgba(31,12,49,.12);
	padding: 8px 18px;
	border-radius: 20px;
	text-decoration: none;
	transition: background .2s ease, border-color .2s ease;
}
.gz-search__suggestion-link:hover { background: var(--gz-deep-indigo); color: var(--gz-ivory); border-color: var(--gz-deep-indigo); text-decoration: none; }

.gz-search__fallback { width: 100%; margin-top: 40px; text-align: left; }
.gz-search__fallback-title {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: rgba(31,12,49,.4);
	margin: 0 0 20px;
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(31,12,49,.08);
}

/* Responsive */
@media screen and (max-width: 767px) {
	.gz-search__hero { padding: calc(80px + 36px) 20px 40px; }
	.gz-search__inner { padding: 0 16px; }
	.gz-search-result { flex-wrap: wrap; }
	.gz-search-result__thumb-link { display: none; }
}

/*--------------------------------------------------------------
# Comments
--------------------------------------------------------------*/

.gz-comments {
	font-family: var(--gz-font-body);
}

.gz-comments__title {
	font-family: var(--gz-font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 28px;
	padding-bottom: 16px;
	border-bottom: 2px solid var(--gz-gold);
	display: inline-block;
}
.gz-comments__count {
	color: var(--gz-teal);
	font-variant-numeric: tabular-nums;
}
.gz-comments__closed {
	font-size: .875rem;
	color: rgba(31,12,49,.45);
	font-style: italic;
	margin: 20px 0 0;
}

/* Comment list */
.gz-comment-list,
.gz-comment-list .children {
	list-style: none;
	margin: 0;
	padding: 0;
}

.gz-comment-list .children {
	padding-left: 56px;
	border-left: 2px solid rgba(31,12,49,.06);
	margin-top: 0;
}

.gz-comment {
	padding: 24px 0;
	border-bottom: 1px solid rgba(31,12,49,.07);
}
.gz-comment:last-child { border-bottom: none; }

.gz-comment__inner {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}
.gz-comment__avatar { flex-shrink: 0; }
.gz-comment__avatar-img {
	width: 48px; height: 48px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid rgba(31,12,49,.08);
}

.gz-comment__body { flex: 1; min-width: 0; }

.gz-comment__header {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 10px;
}
.gz-comment__author {
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
}
.gz-comment__date {
	font-size: .75rem;
	color: rgba(31,12,49,.4);
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: 4px;
}
.gz-comment__date:hover { color: var(--gz-teal); text-decoration: none; }
.gz-comment__time { opacity: .7; }
.gz-comment__pending {
	font-size: .6875rem;
	font-weight: 600;
	background: rgba(250,208,44,.2);
	color: rgba(31,12,49,.6);
	padding: 2px 8px;
	border-radius: 20px;
}

.gz-comment__text {
	font-size: .9375rem;
	line-height: 1.7;
	color: rgba(31,12,49,.75);
}
.gz-comment__text p { margin-bottom: .8em; }
.gz-comment__text p:last-child { margin-bottom: 0; }

.gz-comment__actions {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 10px;
}
.gz-comment__reply a,
.gz-comment__edit a {
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	text-decoration: none;
	transition: color .2s ease;
}
.gz-comment__reply a { color: var(--gz-teal); }
.gz-comment__reply a:hover { color: var(--gz-purple); text-decoration: none; }
.gz-comment__edit a { color: rgba(31,12,49,.35); }
.gz-comment__edit a:hover { color: var(--gz-deep-indigo); text-decoration: none; }

/* Comment navigation */
.comment-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 16px 0;
}
.comment-navigation .nav-links a {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 600;
	color: var(--gz-teal);
	text-decoration: none;
	transition: color .2s ease;
}
.comment-navigation .nav-links a:hover { color: var(--gz-purple); text-decoration: none; }

/* Comment form */
.gz-comment-form { margin-top: 48px; padding-top: 40px; border-top: 2px solid rgba(31,12,49,.08); }
.gz-comment-form__title {
	font-family: var(--gz-font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 6px;
}
.gz-comment-form__cancel a {
	font-size: .75rem;
	color: rgba(31,12,49,.4);
	text-decoration: none;
	margin-left: 10px;
}
.gz-comment-form__cancel a:hover { color: var(--gz-teal); text-decoration: none; }

.gz-comment-form__fields {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 24px;
}
.gz-comment-form__field { display: flex; flex-direction: column; gap: 6px; }
.gz-comment-form__field--full { grid-column: 1 / -1; }

.gz-comment-form__label {
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: rgba(31,12,49,.6);
}
.gz-comment-form__label .required { color: var(--gz-teal); margin-left: 2px; }

.gz-comment-form__input,
.gz-comment-form__textarea {
	font-family: var(--gz-font-body);
	font-size: .9375rem;
	color: var(--gz-deep-indigo);
	background: #fff;
	border: 1px solid rgba(31,12,49,.15);
	border-radius: 6px;
	padding: 11px 14px;
	width: 100%;
	box-sizing: border-box;
	transition: border-color .2s ease, box-shadow .2s ease;
}
.gz-comment-form__input:focus,
.gz-comment-form__textarea:focus {
	border-color: var(--gz-teal);
	box-shadow: 0 0 0 3px rgba(0,104,122,.1);
	outline: none;
}
.gz-comment-form__textarea { resize: vertical; min-height: 140px; line-height: 1.6; }
.gz-comment-form__note {
	font-size: .6875rem;
	color: rgba(31,12,49,.4);
	margin: 4px 0 0;
}

.gz-comment-form__submit {
	grid-column: 1 / -1;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--gz-deep-indigo);
	color: var(--gz-ivory);
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	border: none;
	border-radius: 4px;
	padding: 14px 28px;
	cursor: pointer;
	min-height: unset;
	width: fit-content;
	box-shadow: none;
	transition: background .2s ease, transform .15s ease;
}
.gz-comment-form__submit:hover {
	background: var(--gz-purple);
	transform: translateY(-1px);
	box-shadow: none;
}

/* Responsive */
@media screen and (max-width: 640px) {
	.gz-comment-list .children { padding-left: 20px; }
	.gz-comment-form__fields { grid-template-columns: 1fr; }
	.gz-comment-form__field--full { grid-column: auto; }
}

/*--------------------------------------------------------------
# AJAX Live Search Results Panel
--------------------------------------------------------------*/

/* ── Container ── */
.gz-ajax-results {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--gz-deep-indigo);
	border-top: 1px solid rgba(250,247,240,.08);
	z-index: 200;
	max-height: 70vh;
	overflow-y: auto;
	overscroll-behavior: contain;
	box-shadow: 0 16px 40px rgba(0,0,0,.4);
}

/* Make the search panel position:relative so the dropdown anchors to it */
.gz-header__search-panel {
	position: relative;
}

/* ── List reset ── */
.gz-ajax-results__list {
	list-style: none;
	margin: 0;
	padding: 8px 0;
}

/* ── Single result item ── */
.gz-ajax-results__item {
	margin: 0;
	border-bottom: 1px solid rgba(250,247,240,.05);
}
.gz-ajax-results__item:last-child { border-bottom: none; }

.gz-ajax-results__link {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 12px 24px;
	text-decoration: none;
	transition: background .15s ease;
	outline: none;
}
.gz-ajax-results__link:hover,
.gz-ajax-results__link:focus {
	background: rgba(250,247,240,.06);
	text-decoration: none;
}
.gz-ajax-results__item[aria-selected="true"] .gz-ajax-results__link {
	background: rgba(250,208,44,.08);
}

/* Thumbnail */
.gz-ajax-results__thumb-wrap {
	flex-shrink: 0;
	width: 52px;
	height: 52px;
	border-radius: 6px;
	overflow: hidden;
	background: rgba(250,247,240,.07);
}
.gz-ajax-results__thumb {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.gz-ajax-results__thumb-wrap--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(250,247,240,.2);
}

/* Content */
.gz-ajax-results__content { flex: 1; min-width: 0; }

.gz-ajax-results__badges {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 3px;
}
.gz-ajax-results__type {
	font-family: var(--gz-font-body);
	font-size: .5625rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding: 1px 6px;
	border-radius: 20px;
}
.gz-ajax-results__type--post { background: rgba(0,104,122,.3); color: #6dd5e5; }
.gz-ajax-results__type--page { background: rgba(92,58,142,.35); color: #c4a5f5; }
.gz-ajax-results__cat {
	font-family: var(--gz-font-body);
	font-size: .5625rem;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: rgba(250,247,240,.35);
}

.gz-ajax-results__title {
	font-family: var(--gz-font-body);
	font-size: .9375rem;
	font-weight: 600;
	color: var(--gz-ivory);
	margin: 0 0 2px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.3;
}
.gz-ajax-results__title mark {
	background: rgba(250,208,44,.3);
	color: var(--gz-gold);
	border-radius: 2px;
	padding: 0 2px;
}

.gz-ajax-results__excerpt {
	font-family: var(--gz-font-body);
	font-size: .75rem;
	color: rgba(250,247,240,.45);
	margin: 0 0 3px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.4;
}
.gz-ajax-results__excerpt mark {
	background: rgba(250,208,44,.2);
	color: rgba(250,247,240,.8);
	border-radius: 2px;
	padding: 0 2px;
}

.gz-ajax-results__date {
	font-family: var(--gz-font-body);
	font-size: .625rem;
	color: rgba(250,247,240,.25);
}

/* Arrow */
.gz-ajax-results__arrow {
	flex-shrink: 0;
	color: rgba(250,247,240,.18);
	transition: color .15s ease, transform .15s ease;
}
.gz-ajax-results__link:hover .gz-ajax-results__arrow,
.gz-ajax-results__link:focus .gz-ajax-results__arrow {
	color: var(--gz-gold);
	transform: translateX(3px);
}

/* ── Footer — view all ── */
.gz-ajax-results__footer {
	padding: 10px 24px;
	border-top: 1px solid rgba(250,247,240,.07);
	background: rgba(0,0,0,.15);
}
.gz-ajax-results__view-all {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	color: rgba(250,247,240,.55);
	text-decoration: none;
	transition: color .15s ease, gap .15s ease;
}
.gz-ajax-results__view-all strong { color: var(--gz-gold); font-weight: 700; }
.gz-ajax-results__view-all:hover { color: var(--gz-ivory); gap: 8px; text-decoration: none; }
.gz-ajax-results__view-all svg { flex-shrink: 0; }

/* ── Loading skeleton ── */
.gz-ajax-results__loading {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 20px 24px;
	color: rgba(250,247,240,.4);
	font-family: var(--gz-font-body);
	font-size: .875rem;
}

.gz-ajax-results__spinner {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(250,247,240,.15);
	border-top-color: var(--gz-gold);
	border-radius: 50%;
	flex-shrink: 0;
	animation: gz-spin .7s linear infinite;
}

@keyframes gz-spin {
	to { transform: rotate(360deg); }
}

/* ── Empty / error state ── */
.gz-ajax-results__empty {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 20px 24px;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	color: rgba(250,247,240,.45);
}
.gz-ajax-results__empty svg { flex-shrink: 0; color: rgba(250,247,240,.2); }
.gz-ajax-results__empty strong { color: rgba(250,247,240,.7); }

/* ── Scrollbar inside results ── */
.gz-ajax-results::-webkit-scrollbar { width: 4px; }
.gz-ajax-results::-webkit-scrollbar-track { background: transparent; }
.gz-ajax-results::-webkit-scrollbar-thumb { background: rgba(250,247,240,.15); border-radius: 4px; }

/*--------------------------------------------------------------
# Team Widget & Cards
--------------------------------------------------------------*/

.gz-team { width: 100%; }
.gz-team--bg-ivory  { background: var(--gz-ivory); }
.gz-team--bg-white  { background: #fff; }
.gz-team--bg-indigo { background: var(--gz-deep-indigo); }
.gz-team--bg-indigo .gz-team__title   { color: var(--gz-ivory); }
.gz-team--bg-indigo .gz-team__subtitle { color: rgba(250,247,240,.6); }

.gz-team__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 60px 40px;
}

.gz-team__header {
	text-align: center;
	margin-bottom: 56px;
}

.gz-team__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 0 0 12px;
	letter-spacing: -.02em;
}

.gz-team__subtitle {
	font-family: var(--gz-font-body);
	font-size: 1rem;
	color: rgba(31,12,49,.6);
	max-width: 580px;
	margin: 0 auto;
	line-height: 1.6;
}

/* ── Grid ── */
.gz-team__grid { display: grid; gap: 24px; }
.gz-team__grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.gz-team__grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.gz-team__grid--cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ── Card ── */
.gz-team-card {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
}

.gz-team-card__inner {
	display: block;
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	border-radius: 12px;
	background: var(--gz-deep-indigo);
}

/* ── Photo fills the card ── */
.gz-team-card__photo {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.gz-team-card__photo-img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
	transition: transform .55s cubic-bezier(0.4, 0, 0.2, 1);
}
.gz-team-card:hover .gz-team-card__photo-img { transform: scale(1.08); }

/* Placeholder (no image) */
.gz-team-card__photo-placeholder {
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(145deg, var(--gz-deep-indigo) 0%, var(--gz-purple) 100%);
}

.gz-team-card__initials {
	font-family: var(--gz-font-heading);
	font-size: clamp(3rem, 8vw, 5rem);
	font-weight: 700;
	color: rgba(250,247,240,.15);
	letter-spacing: -.02em;
}

/* Gold shimmer bar (always visible, left edge) */
.gz-team-card__shimmer {
	position: absolute;
	top: 0;
	left: 0;
	width: 3px;
	height: 100%;
	background: linear-gradient(to bottom, var(--gz-gold) 0%, rgba(250,208,44,0) 100%);
	opacity: 0;
	transition: opacity .35s ease;
	z-index: 5;
}
.gz-team-card:hover .gz-team-card__shimmer { opacity: 1; }

/* ── Hover overlay (slides up) ── */
.gz-team-card__hover {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	align-items: flex-end;
	padding-bottom: 100px; /* clear the bottom info bar */
	background: linear-gradient(to top, rgba(31,12,49,0) 0%, rgba(31,12,49,.85) 100%);
	opacity: 0;
	transition: opacity .35s ease;
	pointer-events: none;
}
.gz-team-card:hover .gz-team-card__hover {
	opacity: 1;
	pointer-events: auto;
}

.gz-team-card__hover-inner {
	width: 100%;
	padding: 24px 22px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	transform: translateY(12px);
	transition: transform .4s ease;
}
.gz-team-card:hover .gz-team-card__hover-inner { transform: translateY(0); }

.gz-team-card__hover-dept {
	font-family: var(--gz-font-body);
	font-size: .5625rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--gz-gold);
}

.gz-team-card__hover-bio {
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	color: rgba(250,247,240,.8);
	line-height: 1.55;
	margin: 0;
}

.gz-team-card__hover-social {
	display: flex;
	gap: 8px;
}

.gz-team-card__hover-social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px; height: 32px;
	border-radius: 50%;
	background: rgba(250,247,240,.1);
	border: 1px solid rgba(250,247,240,.15);
	color: rgba(250,247,240,.7);
	text-decoration: none;
	transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.gz-team-card__hover-social-link:hover {
	background: var(--gz-gold);
	color: var(--gz-deep-indigo);
	border-color: var(--gz-gold);
	text-decoration: none;
}

.gz-team-card__hover-cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--gz-font-body);
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--gz-gold);
	text-decoration: none;
	transition: gap .2s ease;
}
.gz-team-card__hover-cta:hover { gap: 9px; text-decoration: none; }

/* ── Bottom info bar (always visible) ── */
.gz-team-card__bottom {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	z-index: 4;
	padding: 52px 22px 20px;
	background: linear-gradient(to top, rgba(31,12,49,.97) 40%, transparent 100%);
	display: flex;
	flex-direction: column;
	gap: 3px;
	transition: padding-bottom .35s ease;
}
.gz-team-card:hover .gz-team-card__bottom { padding-bottom: 22px; }

.gz-team-card__bottom-role {
	font-family: var(--gz-font-body);
	font-size: .625rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--gz-teal);
}

.gz-team-card__bottom-name {
	font-family: var(--gz-font-heading);
	font-size: clamp(1rem, 1.8vw, 1.25rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0;
	line-height: 1.2;
}
.gz-team-card__bottom-name a { color: inherit; text-decoration: none; }
.gz-team-card__bottom-name a:hover { color: var(--gz-gold); text-decoration: none; }

.gz-team-card__bottom-location {
	display: flex;
	align-items: center;
	gap: 4px;
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	color: rgba(250,247,240,.45);
	margin-top: 2px;
}

/* ── Section CTA ── */
.gz-team__cta { text-align: center; margin-top: 48px; }
.gz-team__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--gz-deep-indigo);
	background: var(--gz-gold);
	padding: 14px 32px;
	border-radius: 4px;
	text-decoration: none;
	transition: background .2s ease, transform .15s ease;
}
.gz-team__cta-btn:hover { background: var(--gz-gold-dark); transform: translateY(-2px); text-decoration: none; }

/* ── Responsive ── */
@media screen and (max-width: 1280px) {
	.gz-team__grid--cols-4 { grid-template-columns: repeat(3, 1fr); }
}
@media screen and (max-width: 1023px) {
	.gz-team__grid--cols-4,
	.gz-team__grid--cols-3 { grid-template-columns: repeat(2, 1fr); }
	.gz-team-card__hover { display: none; } /* too tight for overlay on tablet */
	.gz-team-card__bottom { padding-top: 72px; }
}
@media screen and (max-width: 640px) {
	.gz-team__grid--cols-4,
	.gz-team__grid--cols-3,
	.gz-team__grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
	.gz-team__inner { padding: 40px 16px; }
}
@media screen and (max-width: 360px) {
	.gz-team__grid { grid-template-columns: 1fr; }
}

/*--------------------------------------------------------------
# Team Archive Page
--------------------------------------------------------------*/

.gz-team-archive {
	background: var(--gz-ivory);
	width: 100%;
}

/* ── Hero Section ── */
.gz-team-archive__hero {
	background-color: var(--gz-deep-indigo);
	background-size: cover;
	background-position: center;
	padding: 100px 40px 80px;
	position: relative;
	overflow: hidden;
	text-align: center;
}

/* Dark overlay for text readability (works with or without background image) */
.gz-team-archive__hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(31, 12, 49, 0.85) 0%, rgba(74, 47, 116, 0.85) 100%);
	z-index: 1;
}

.gz-team-archive__hero-inner {
	max-width: 720px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}

.gz-team-archive__eyebrow {
	font-family: var(--gz-font-body);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--gz-gold);
	margin: 0 0 16px;
}

.gz-team-archive__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 20px;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.gz-team-archive__subtitle {
	font-family: var(--gz-font-body);
	font-size: 1.0625rem;
	color: rgba(250, 247, 240, 0.85);
	line-height: 1.6;
	margin: 0;
}

/* ── Decorative Gem SVG ── */
.gz-team-archive__gem {
	position: absolute;
	top: 50%;
	right: -100px;
	width: 400px;
	height: 400px;
	transform: translateY(-50%);
	opacity: 0.08;
	z-index: 1;
	pointer-events: none;
	color: var(--gz-ivory);
}

.gz-team-archive__gem svg {
	width: 100%;
	height: 100%;
}

/* ── Main Content ── */
.gz-team-archive__main {
	width: 100%;
	padding: 80px 0;
}

.gz-team-archive__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
}

/* ── Responsive Adjustments ── */
@media screen and (max-width: 1023px) {
	.gz-team-archive__hero {
		padding: 80px 30px 60px;
	}

	.gz-team-archive__gem {
		right: -150px;
		width: 300px;
		height: 300px;
		opacity: 0.06;
	}

	.gz-team-archive__title {
		font-size: clamp(1.75rem, 4vw, 2.5rem);
	}

	.gz-team-archive__subtitle {
		font-size: 1rem;
	}

	.gz-team-archive__inner {
		padding: 0 24px;
	}

	.gz-team-archive__main {
		padding: 60px 0;
	}
}

@media screen and (max-width: 640px) {
	.gz-team-archive__hero {
		padding: 60px 20px 50px;
	}

	.gz-team-archive__gem {
		display: none;
	}

	.gz-team-archive__title {
		font-size: clamp(1.5rem, 3vw, 2rem);
		margin-bottom: 16px;
	}

	.gz-team-archive__subtitle {
		font-size: 0.9375rem;
	}

	.gz-team-archive__inner {
		padding: 0 16px;
	}

	.gz-team-archive__main {
		padding: 40px 0;
	}
}

/*--------------------------------------------------------------
# Single Team Member Page
--------------------------------------------------------------*/

.gz-member { background: var(--gz-ivory); }

/* Hero */
.gz-member__hero {
	background: var(--gz-deep-indigo);
	padding: calc(80px + 48px) 40px 56px;
	margin-top: -80px;
	position: relative;
	overflow: hidden;
}
.gz-member__hero::before {
	content: '';
	position: absolute;
	top: -30%;
	right: -5%;
	width: 500px;
	height: 500px;
	background: radial-gradient(circle, rgba(92,58,142,.2) 0%, transparent 65%);
	pointer-events: none;
}

.gz-member__hero-inner {
	max-width: 1100px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}

/* Profile layout */
.gz-member__profile {
	display: flex;
	align-items: center;
	gap: 48px;
	margin-top: 24px;
}

.gz-member__photo-col { flex-shrink: 0; }

.gz-member__photo-wrap {
	position: relative;
	width: 180px;
	height: 180px;
}

.gz-member__photo {
	width: 180px;
	height: 180px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	position: relative;
	z-index: 2;
}

.gz-member__photo--placeholder {
	background: rgba(250,247,240,.08);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(250,247,240,.2);
}

.gz-member__photo-ring {
	position: absolute;
	inset: -6px;
	border-radius: 50%;
	border: 2px solid var(--gz-gold);
	opacity: .5;
	z-index: 1;
	animation: gz-ring-pulse 3s ease-in-out infinite;
}

@keyframes gz-ring-pulse {
	0%, 100% { opacity: .5; transform: scale(1); }
	50%       { opacity: .8; transform: scale(1.02); }
}

.gz-member__info-col { flex: 1; }

.gz-member__depts { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.gz-member__dept-badge {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--gz-deep-indigo);
	background: var(--gz-gold);
	padding: 4px 12px;
	border-radius: 20px;
	text-decoration: none;
}
.gz-member__dept-badge:hover { background: #fff; text-decoration: none; }

.gz-member__name {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem, 4vw, 3.25rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 8px;
	letter-spacing: -.025em;
	line-height: 1.1;
}

.gz-member__role {
	font-family: var(--gz-font-body);
	font-size: 1.0625rem;
	color: var(--gz-gold);
	font-weight: 500;
	margin: 0 0 10px;
}

.gz-member__location {
	display: flex;
	align-items: center;
	gap: 5px;
	font-family: var(--gz-font-body);
	font-size: .875rem;
	color: rgba(250,247,240,.5);
	margin: 0 0 20px;
}

/* Social links */
.gz-member__socials { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }

.gz-member__social {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	color: rgba(250,247,240,.5);
	text-decoration: none;
	background: rgba(250,247,240,.08);
	border: 1px solid rgba(250,247,240,.12);
	border-radius: 20px;
	padding: 7px 14px;
	transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.gz-member__social:hover { background: var(--gz-gold); color: var(--gz-deep-indigo); border-color: var(--gz-gold); text-decoration: none; }
.gz-member__social--email { color: rgba(250,247,240,.7); }

/* Body layout */
.gz-member__body { padding: 60px 0; }
.gz-member__body-inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 40px;
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 60px;
	align-items: start;
}

.gz-member__prose { font-size: 1.0625rem; }

/* Expertise tags */
.gz-member__expertise { margin-top: 40px; padding-top: 32px; border-top: 1px solid rgba(31,12,49,.1); }
.gz-member__expertise-heading {
	font-family: var(--gz-font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: rgba(31,12,49,.4);
	margin: 0 0 14px;
}
.gz-member__expertise-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.gz-member__expertise-tag {
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 500;
	color: var(--gz-purple);
	background: rgba(92,58,142,.08);
	border: 1px solid rgba(92,58,142,.15);
	padding: 5px 14px;
	border-radius: 20px;
}

/* Facts sidebar */
.gz-member__facts-list { margin: 0 0 18px; padding: 0; }
.gz-member__fact {
	display: grid;
	grid-template-columns: 90px 1fr;
	gap: 6px 12px;
	padding: 10px 0;
	border-bottom: 1px solid rgba(31,12,49,.07);
}
.gz-member__fact:last-child { border-bottom: none; }
.gz-member__fact dt { font-family: var(--gz-font-body); font-size: .6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(31,12,49,.4); margin: 0; }
.gz-member__fact dd { font-family: var(--gz-font-body); font-size: .875rem; color: var(--gz-deep-indigo); margin: 0; }

.gz-member__contact-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-family: var(--gz-font-body);
	font-size: .8125rem;
	font-weight: 700;
	color: var(--gz-ivory);
	background: var(--gz-deep-indigo);
	padding: 11px 20px;
	border-radius: 4px;
	text-decoration: none;
	width: 100%;
	justify-content: center;
	transition: background .2s ease;
}
.gz-member__contact-btn:hover { background: var(--gz-purple); text-decoration: none; }

/* Others section */
.gz-member__others {
	background: var(--gz-ivory);
	padding: 64px 0 80px;
	border-top: 1px solid rgba(31,12,49,.08);
}

.gz-member__others-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
}

/* Header row */
.gz-member__others-head {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-bottom: 36px;
}

.gz-member__others-label {
	font-family: var(--gz-font-body);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(31,12,49,.4);
	white-space: nowrap;
}

.gz-member__others-head::after {
	content: '';
	flex: 1;
	height: 1px;
	background: rgba(31,12,49,.1);
}

.gz-member__others-all {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: var(--gz-font-body);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--gz-purple);
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.2s;
}

.gz-member__others-all:hover { color: var(--gz-gold); }

/* Cards grid */
.gz-member__others-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

.gz-member__other-card {
	display: flex;
	align-items: center;
	gap: 14px;
	background: #fff;
	border: 1px solid rgba(31,12,49,.08);
	border-radius: 14px;
	padding: 18px 16px;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.gz-member__other-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 28px rgba(31,12,49,.10);
	border-color: var(--gz-gold);
}

/* Avatar circle */
.gz-member__other-avatar {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	background: linear-gradient(135deg, var(--gz-deep-indigo) 0%, var(--gz-purple) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.gz-member__other-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.gz-member__other-initials {
	font-family: var(--gz-font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--gz-gold);
	line-height: 1;
}

/* Text block */
.gz-member__other-body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.gz-member__other-name {
	font-family: var(--gz-font-heading);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--gz-deep-indigo);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: block;
}

.gz-member__other-role {
	font-size: 0.8rem;
	color: rgba(31,12,49,.55);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: block;
}

.gz-member__other-dept {
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--gz-teal);
	display: block;
}

/* Arrow icon */
.gz-member__other-arrow {
	flex-shrink: 0;
	color: var(--gz-gold);
	opacity: 0;
	transform: translateX(-4px);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.gz-member__other-card:hover .gz-member__other-arrow {
	opacity: 1;
	transform: translateX(0);
}

/* Responsive */
@media screen and (max-width: 1023px) {
	.gz-member__profile { flex-direction: column; align-items: flex-start; gap: 28px; }
	.gz-member__body-inner { grid-template-columns: 1fr; gap: 40px; }
	.gz-member__sidebar { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
	.gz-member__others-inner { padding: 0 24px; }
	.gz-member__others-grid { grid-template-columns: repeat(2, 1fr); }
}

@media screen and (max-width: 767px) {
	.gz-member__hero { padding: calc(80px + 32px) 20px 48px; }
	.gz-member__body-inner { padding: 0 20px; }
	.gz-member__photo-wrap, .gz-member__photo { width: 140px; height: 140px; }
	.gz-member__sidebar { grid-template-columns: 1fr; }
	.gz-member__others-inner { padding: 0 16px; }
	.gz-member__others-grid { grid-template-columns: 1fr; }
}

/*--------------------------------------------------------------
# Single Page (page.php)
--------------------------------------------------------------*/

/* ── Hero ── */
.gz-page__hero {
	background-color: var(--gz-deep-indigo);
	background-size: cover;
	background-position: center top;
	position: relative;
	overflow: hidden;
	text-align: center;
	/* Slide under the transparent fixed header */
	margin-top: -80px;
	padding: calc(80px + 72px) 40px 72px;
	color: var(--gz-ivory);
}

.gz-page__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		160deg,
		rgba(31, 12, 49, 0.92) 0%,
		rgba(74, 47, 116, 0.80) 100%
	);
	z-index: 1;
}

.gz-page__hero--has-image .gz-page__hero-overlay {
	background: linear-gradient(
		160deg,
		rgba(31, 12, 49, 0.82) 0%,
		rgba(31, 12, 49, 0.65) 100%
	);
}

.gz-page__hero-inner {
	position: relative;
	z-index: 2;
	max-width: 780px;
	margin: 0 auto;
}

.gz-page__breadcrumb {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 6px;
	font-family: var(--gz-font-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--gz-gold);
	margin: 0 0 20px;
}

.gz-page__breadcrumb a {
	color: rgba(250, 247, 240, 0.65);
	text-decoration: none;
	transition: color 0.2s;
}

.gz-page__breadcrumb a:hover { color: var(--gz-gold); }

.gz-page__breadcrumb span[aria-hidden] {
	color: rgba(250, 247, 240, 0.3);
}

.gz-page__breadcrumb > span:last-child {
	color: var(--gz-gold);
}

.gz-page__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 20px;
	letter-spacing: -0.02em;
	line-height: 1.15;
}

.gz-page__subtitle {
	font-family: var(--gz-font-body);
	font-size: 1.0625rem;
	color: rgba(250, 247, 240, 0.8);
	line-height: 1.65;
	margin: 0;
	max-width: 600px;
	margin-inline: auto;
}

/* Decorative gem */
.gz-page__gem {
	position: absolute;
	top: 50%;
	right: -80px;
	width: 380px;
	height: 380px;
	transform: translateY(-50%);
	opacity: 0.07;
	z-index: 1;
	pointer-events: none;
	color: var(--gz-ivory);
}

.gz-page__gem svg { width: 100%; height: 100%; }

/* ── Content area ── */
.gz-page__wrap {
	background: var(--gz-ivory);
	padding: 72px 0 96px;
}

.gz-page__container {
	max-width: 820px;
	margin: 0 auto;
	padding: 0 40px;
}

.gz-page__container--narrow {
	max-width: 760px;
}

/* ── Prose typography ── */
.gz-page__prose {
	font-family: var(--gz-font-body);
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--gz-deep-indigo);
}

.gz-page__prose h2 {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	color: var(--gz-deep-indigo);
	margin: 2.5em 0 0.6em;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.gz-page__prose h3 {
	font-family: var(--gz-font-heading);
	font-size: clamp(1.2rem, 2.5vw, 1.5rem);
	font-weight: 600;
	color: var(--gz-deep-indigo);
	margin: 2em 0 0.5em;
}

.gz-page__prose h4 {
	font-size: 1.0625rem;
	font-weight: 700;
	margin: 1.5em 0 0.4em;
}

.gz-page__prose p { margin: 0 0 1.4em; }

.gz-page__prose a {
	color: var(--gz-purple);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.gz-page__prose a:hover { color: var(--gz-gold); }

.gz-page__prose ul,
.gz-page__prose ol {
	margin: 0 0 1.4em 1.5em;
	padding: 0;
}

.gz-page__prose li { margin-bottom: 0.5em; }

.gz-page__prose blockquote {
	border-left: 4px solid var(--gz-gold);
	margin: 2em 0;
	padding: 1em 1.5em;
	background: rgba(31, 12, 49, 0.04);
	border-radius: 0 8px 8px 0;
	font-style: italic;
	font-size: 1.125rem;
	color: var(--gz-purple);
}

.gz-page__prose blockquote p { margin: 0; }

.gz-page__prose img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	margin: 1.5em 0;
}

.gz-page__prose figure { margin: 2em 0; }

.gz-page__prose figcaption {
	font-size: 0.875rem;
	color: rgba(31, 12, 49, 0.55);
	text-align: center;
	margin-top: 0.5em;
}

.gz-page__prose pre {
	background: var(--gz-deep-indigo);
	color: var(--gz-ivory);
	padding: 1.25em 1.5em;
	border-radius: 8px;
	overflow-x: auto;
	font-size: 0.9rem;
	margin: 1.5em 0;
}

.gz-page__prose code {
	background: rgba(31, 12, 49, 0.07);
	padding: 0.2em 0.45em;
	border-radius: 4px;
	font-size: 0.9em;
}

.gz-page__prose pre code {
	background: none;
	padding: 0;
}

.gz-page__prose hr {
	border: none;
	border-top: 2px solid rgba(31, 12, 49, 0.1);
	margin: 3em 0;
}

.gz-page__prose table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9375rem;
	margin: 1.5em 0;
}

.gz-page__prose th {
	background: var(--gz-deep-indigo);
	color: var(--gz-ivory);
	padding: 10px 16px;
	text-align: left;
	font-weight: 600;
}

.gz-page__prose td {
	padding: 10px 16px;
	border-bottom: 1px solid rgba(31, 12, 49, 0.1);
}

.gz-page__prose tr:nth-child(even) td {
	background: rgba(31, 12, 49, 0.03);
}

/* Edit link */
.gz-page__edit {
	margin-top: 48px;
	padding-top: 24px;
	border-top: 1px solid rgba(31, 12, 49, 0.1);
	font-size: 0.875rem;
}

.gz-page__edit a {
	color: var(--gz-purple);
	text-decoration: none;
}

/* Comments */
.gz-page__comments-wrap {
	background: #f4f1ec;
	padding: 64px 0;
}

/* ── Responsive ── */
@media screen and (max-width: 1023px) {
	.gz-page__hero { padding: calc(80px + 56px) 30px 56px; }
	.gz-page__gem { right: -120px; width: 280px; height: 280px; }
	.gz-page__container { padding: 0 24px; }
	.gz-page__wrap { padding: 56px 0 72px; }
}

@media screen and (max-width: 640px) {
	.gz-page__hero { padding: calc(80px + 40px) 20px 48px; text-align: left; }
	.gz-page__breadcrumb { justify-content: flex-start; }
	.gz-page__gem { display: none; }
	.gz-page__container { padding: 0 16px; }
	.gz-page__wrap { padding: 40px 0 56px; }
	.gz-page__prose { font-size: 1rem; }
}
}

/*--------------------------------------------------------------
# Elementor Widget: Hero Header (gz_hero_header)
--------------------------------------------------------------*/

.gz-hero-header {
	position: relative;
	overflow: hidden;
	background-color: var(--gz-deep-indigo);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	min-height: 400px;
	color: var(--gz-ivory);
}

.gz-hero-header__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		150deg,
		rgba(31, 12, 49, 0.92) 0%,
		rgba(74, 47, 116, 0.78) 100%
	);
	z-index: 1;
}

.gz-hero-header__inner {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 860px;
	margin: 0 auto;
	padding: 100px 40px;
	text-align: center;
}

.gz-hero-header__logo {
	margin: 0 auto 28px;
	max-width: 160px;
}

.gz-hero-header__logo img {
	width: 100%;
	height: auto;
	display: block;
}

.gz-hero-header__eyebrow {
	font-family: var(--gz-font-body);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gz-gold);
	margin: 0 0 20px;
}

.gz-hero-header__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0 0 24px;
	letter-spacing: -0.02em;
	line-height: 1.15;
}

.gz-hero-header__description {
	font-family: var(--gz-font-body);
	font-size: 1.125rem;
	color: rgba(250, 247, 240, 0.85);
	line-height: 1.65;
	max-width: 620px;
	margin: 0 auto;
}

/* Decorative gem */
.gz-hero-header__gem {
	position: absolute;
	top: 50%;
	right: -80px;
	width: 420px;
	height: 420px;
	transform: translateY(-50%);
	opacity: 0.08;
	z-index: 1;
	pointer-events: none;
	color: var(--gz-ivory);
}

.gz-hero-header__gem svg {
	width: 100%;
	height: 100%;
}

/* Responsive */
@media screen and (max-width: 1023px) {
	.gz-hero-header__inner { padding: 80px 30px; }
	.gz-hero-header__gem { right: -120px; width: 300px; height: 300px; }
}

@media screen and (max-width: 640px) {
	.gz-hero-header { min-height: 280px; }
	.gz-hero-header__inner { padding: 64px 20px; text-align: left; }
	.gz-hero-header__eyebrow { text-align: left; }
	.gz-hero-header__gem { display: none; }
}

/*--------------------------------------------------------------
# Services Archive
--------------------------------------------------------------*/

.gz-services-archive { background: var(--gz-ivory); }

.gz-services-archive__hero {
	background-color: var(--gz-deep-indigo);
	background-size: cover;
	background-position: center;
	padding: 100px 40px 80px;
	position: relative;
	overflow: hidden;
	text-align: center;
	color: var(--gz-ivory);
}

.gz-services-archive__hero-inner {
	position: relative;
	z-index: 2;
	max-width: 860px;
	margin: 0 auto;
	padding: 0 40px;
}

.gz-services-archive__eyebrow {
	font-size: 0.75rem; font-weight: 700; letter-spacing: 0.1em;
	text-transform: uppercase; color: var(--gz-gold); margin: 0 0 16px;
}

.gz-services-archive__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem,5vw,3.25rem);
	font-weight: 700; color: var(--gz-ivory);
	margin: 0 0 20px; letter-spacing: -0.02em; line-height: 1.2;
}

.gz-services-archive__subtitle {
	font-size: 1.0625rem; color: rgba(250,247,240,.85); line-height: 1.6; margin: 0;
}

.gz-services-archive__gem {
	position: absolute; top: 50%; right: -80px;
	width: 380px; height: 380px; transform: translateY(-50%);
	opacity: 0.07; z-index: 1; pointer-events: none; color: var(--gz-ivory);
}

.gz-services-archive__main { width: 100%; padding: 72px 0 96px; }
.gz-services-archive__inner { max-width: 1280px; margin: 0 auto; padding: 0 40px; }

/* Services grid */
.gz-services__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

/* ── Service card — mirrors team card pattern ── */
.gz-service-card {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
}

.gz-service-card__inner {
	display: block;
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	border-radius: 12px;
	background: var(--gz-deep-indigo);
}

/* ── Photo / placeholder fills the card ── */
.gz-service-card__photo {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.gz-service-card__photo-img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform .55s cubic-bezier(0.4,0,0.2,1);
}

.gz-service-card:hover .gz-service-card__photo-img { transform: scale(1.08); }

/* Illustrated placeholder */
.gz-service-card__photo-placeholder {
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	color: rgba(250,247,240,1);
}

/* Large faded icon — same role as team initials */
.gz-service-card__icon-bg {
	font-size: clamp(5rem,12vw,8rem);
	opacity: 0.13;
	position: absolute;
	transform: rotate(-8deg) scale(1.1);
	pointer-events: none;
	user-select: none;
	transition: transform .55s ease, opacity .4s ease;
}

.gz-service-card:hover .gz-service-card__icon-bg {
	opacity: 0.2;
	transform: rotate(-4deg) scale(1.18);
}

/* Decorative gem polygon SVG */
.gz-service-card__gem-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	color: #fff;
}

/* Gold shimmer bar — left edge, same as team card */
.gz-service-card__shimmer {
	position: absolute;
	top: 0; left: 0;
	width: 3px; height: 100%;
	background: linear-gradient(to bottom, var(--gz-gold) 0%, rgba(250,208,44,0) 100%);
	opacity: 0;
	transition: opacity .35s ease;
	z-index: 5;
}
.gz-service-card:hover .gz-service-card__shimmer { opacity: 1; }

/* ── Hover overlay (slides up from centre) ── */
.gz-service-card__hover {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	align-items: flex-end;
	padding-bottom: 108px; /* clears bottom bar */
	background: linear-gradient(to top, rgba(31,12,49,0) 0%, rgba(31,12,49,.88) 100%);
	opacity: 0;
	transition: opacity .35s ease;
	pointer-events: none;
}
.gz-service-card:hover .gz-service-card__hover {
	opacity: 1;
	pointer-events: auto;
}

.gz-service-card__hover-inner {
	width: 100%;
	padding: 24px 22px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	transform: translateY(14px);
	transition: transform .4s ease;
}
.gz-service-card:hover .gz-service-card__hover-inner { transform: translateY(0); }

.gz-service-card__hover-type {
	font-size: .5625rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--gz-gold);
}

.gz-service-card__hover-excerpt {
	font-size: .8125rem;
	color: rgba(250,247,240,.82);
	line-height: 1.55;
	margin: 0;
}

.gz-service-card__hover-duration {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: .75rem;
	color: rgba(250,247,240,.55);
}

.gz-service-card__hover-cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--gz-gold);
	text-decoration: none;
	transition: gap .2s ease;
}
.gz-service-card__hover-cta:hover { gap: 9px; text-decoration: none; }

/* ── Bottom bar (always visible) — same pattern as team card ── */
.gz-service-card__bottom {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	z-index: 4;
	padding: 52px 22px 20px;
	background: linear-gradient(to top, rgba(31,12,49,.97) 40%, transparent 100%);
	display: flex;
	flex-direction: column;
	gap: 3px;
	transition: padding-bottom .35s ease;
}
.gz-service-card:hover .gz-service-card__bottom { padding-bottom: 22px; }

.gz-service-card__bottom-type {
	font-size: .5625rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--gz-teal);
}

.gz-service-card__bottom-name {
	font-family: var(--gz-font-heading);
	font-size: clamp(1rem,1.8vw,1.2rem);
	font-weight: 700;
	color: var(--gz-ivory);
	margin: 0;
	line-height: 1.25;
}
.gz-service-card__bottom-name a { color: inherit; text-decoration: none; }

.gz-service-card__bottom-price {
	font-size: .8125rem;
	font-weight: 700;
	color: var(--gz-gold);
}
.gz-service-card__bottom-price--inquiry {
	color: rgba(250,247,240,.45);
	font-weight: 400;
	font-style: italic;
}

/* single-page panel classes (unchanged) */
.gz-service-card__price-amount {
	font-family: var(--gz-font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--gz-gold);
}
.gz-service-card__price-inquiry {
	font-size: 0.8125rem;
	color: rgba(31,12,49,.45);
	font-style: italic;
}

@media screen and (max-width: 1023px) {
	.gz-services__grid { grid-template-columns: repeat(2,1fr); gap: 20px; }
	.gz-services-archive__inner { padding: 0 24px; }
	.gz-services-archive__hero-inner { padding: 0 24px; }
}
@media screen and (max-width: 640px) {
	.gz-services__grid { grid-template-columns: 1fr; }
	.gz-services-archive__hero { padding: 72px 0 56px; }
	.gz-services-archive__hero-inner { padding: 0 16px; }
	.gz-services-archive__inner { padding: 0 16px; }
	.gz-services-archive__main { padding: 48px 0 64px; }
}

/*--------------------------------------------------------------
# Single Service Page
--------------------------------------------------------------*/

.gz-service { background: var(--gz-ivory); }

/* Hero */
.gz-service__hero {
	background-color: var(--gz-deep-indigo);
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
	margin-top: -80px;
	padding: calc(80px + 72px) 0 72px;
	color: var(--gz-ivory);
}

.gz-service__hero-overlay {
	position: absolute; inset: 0; z-index: 1;
	background: linear-gradient(160deg, rgba(31,12,49,.94) 0%, rgba(74,47,116,.82) 100%);
}

.gz-service__hero--has-image .gz-service__hero-overlay {
	background: linear-gradient(160deg, rgba(31,12,49,.88) 0%, rgba(31,12,49,.65) 100%);
}

/* Hero inner: same max-width + padding as the content container so left edges align */
.gz-service__hero-inner {
	position: relative;
	z-index: 2;
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 40px;
}

.gz-service__types { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0; }

.gz-service__title {
	font-family: var(--gz-font-heading);
	font-size: clamp(2rem,5vw,3rem);
	font-weight: 700; color: var(--gz-ivory);
	margin: 0 0 16px; letter-spacing: -0.02em; line-height: 1.15;
}

.gz-service__subtitle {
	font-size: 1.0625rem; color: rgba(250,247,240,.82); line-height: 1.65; margin: 0 0 24px;
	max-width: 640px;
}

.gz-service__hero-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; }

.gz-service__hero-meta-item {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 0.875rem; color: rgba(250,247,240,.7);
}

.gz-service__hero-price {
	font-family: var(--gz-font-heading);
	font-size: 1.375rem; font-weight: 700;
	color: var(--gz-gold);
}

/* Payment status banner */
.gz-service__payment-banner {
	display: flex; align-items: center; gap: 12px;
	padding: 16px 40px; font-size: 0.9375rem;
}

.gz-service__payment-banner--pending { background: #fff8e1; color: #856404; border-bottom: 2px solid #ffc107; }
.gz-service__payment-banner--success { background: #e8f5e9; color: #1b5e20; border-bottom: 2px solid #4caf50; }

/* Layout */
.gz-service__layout { padding: 64px 0 96px; }

.gz-service__container {
	max-width: 1180px; margin: 0 auto; padding: 0 40px;
	display: grid; grid-template-columns: 1fr 380px; gap: 56px; align-items: start;
}

/* Content */
.gz-service__prose { font-size: 1.0625rem; line-height: 1.75; color: var(--gz-deep-indigo); }
.gz-service__prose h2 { font-family: var(--gz-font-heading); font-size: clamp(1.4rem,3vw,1.875rem); font-weight: 700; margin: 2em 0 0.6em; }
.gz-service__prose h3 { font-family: var(--gz-font-heading); font-size: 1.25rem; font-weight: 600; margin: 1.5em 0 0.5em; }
.gz-service__prose p { margin: 0 0 1.4em; }
.gz-service__prose a { color: var(--gz-purple); text-decoration: underline; text-underline-offset: 3px; }
.gz-service__prose ul,.gz-service__prose ol { margin: 0 0 1.4em 1.5em; }

/* Deliverables */
.gz-service__deliverables { margin-top: 48px; padding-top: 40px; border-top: 2px solid rgba(31,12,49,.08); }

.gz-service__deliverables-heading {
	font-family: var(--gz-font-heading); font-size: 1.375rem; font-weight: 700;
	color: var(--gz-deep-indigo); margin: 0 0 24px;
}

.gz-service__deliverables-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }

.gz-service__deliverable {
	display: flex; align-items: flex-start; gap: 12px;
	font-size: 1rem; color: rgba(31,12,49,.85); line-height: 1.5;
}

.gz-service__deliverable-check {
	flex-shrink: 0; margin-top: 2px; color: var(--gz-teal);
}

/* Sidebar panel */
.gz-service__sidebar { position: sticky; top: 100px; }

.gz-service__panel {
	background: #fff;
	border: 1px solid rgba(31,12,49,.08);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 8px 32px rgba(31,12,49,.08);
}

.gz-service__panel-price {
	background: var(--gz-deep-indigo);
	padding: 24px 28px;
	display: flex; flex-direction: column; gap: 4px;
}

.gz-service__panel-price-from { font-size: 0.75rem; color: rgba(250,247,240,.6); text-transform: uppercase; letter-spacing: 0.08em; }
.gz-service__panel-price-amount { font-family: var(--gz-font-heading); font-size: 2rem; font-weight: 700; color: var(--gz-gold); line-height: 1.1; }
.gz-service__panel-duration { font-size: 0.8125rem; color: rgba(250,247,240,.5); margin-top: 4px; }

/* Tabs */
.gz-service__tabs {
	display: grid; grid-template-columns: 1fr 1fr;
	border-bottom: 1px solid rgba(31,12,49,.08);
}

.gz-service__tab {
	display: flex; align-items: center; justify-content: center; gap: 6px;
	padding: 14px 10px; font-size: 0.8125rem; font-weight: 600;
	color: rgba(31,12,49,.5); background: none; border: none; cursor: pointer;
	border-bottom: 2px solid transparent; transition: color 0.2s, border-color 0.2s;
}

.gz-service__tab--active { color: var(--gz-deep-indigo); border-bottom-color: var(--gz-gold); }
.gz-service__tab:hover { color: var(--gz-deep-indigo); }

/* Forms */
.gz-service__form { padding: 24px 28px; display: flex; flex-direction: column; gap: 16px; }
.gz-service__form--hidden { display: none; }

.gz-service__field { display: flex; flex-direction: column; gap: 5px; }

.gz-service__field label {
	font-size: 0.8rem; font-weight: 600; color: rgba(31,12,49,.7);
	text-transform: uppercase; letter-spacing: 0.05em;
}

.gz-service__field label span { color: var(--gz-gold); }

.gz-service__field input,
.gz-service__field textarea {
	width: 100%; padding: 10px 14px;
	border: 1.5px solid rgba(31,12,49,.15); border-radius: 8px;
	font-family: var(--gz-font-body); font-size: 0.9375rem;
	color: var(--gz-deep-indigo); background: var(--gz-ivory);
	transition: border-color 0.2s, box-shadow 0.2s;
	box-sizing: border-box;
}

.gz-service__field input:focus,
.gz-service__field textarea:focus {
	outline: none;
	border-color: var(--gz-purple);
	box-shadow: 0 0 0 3px rgba(92,58,142,.12);
}

.gz-service__field textarea { resize: vertical; min-height: 80px; }

/* Buttons */
.gz-service__submit {
	display: flex; align-items: center; justify-content: center; gap: 8px;
	width: 100%; padding: 14px 20px; border: none; border-radius: 10px;
	font-family: var(--gz-font-body); font-size: 0.9375rem; font-weight: 700;
	cursor: pointer; transition: opacity 0.2s, transform 0.15s;
}

.gz-service__submit:active { transform: scale(0.98); }
.gz-service__submit:disabled { opacity: 0.65; cursor: not-allowed; }

.gz-service__submit--pay { background: var(--gz-gold); color: var(--gz-deep-indigo); }
.gz-service__submit--pay:hover { opacity: 0.9; }

.gz-service__submit--inquiry { background: var(--gz-deep-indigo); color: var(--gz-ivory); }
.gz-service__submit--inquiry:hover { opacity: 0.88; }

.gz-service__pesapal-note {
	display: flex; align-items: center; gap: 6px;
	font-size: 0.75rem; color: rgba(31,12,49,.45); margin: 0; justify-content: center;
}

/* Form message */
.gz-service__form-msg {
	margin: 0 28px 0;
	padding: 12px 16px; border-radius: 8px;
	font-size: 0.9rem; line-height: 1.5;
}

.gz-service__form-msg--success { background: #e8f5e9; color: #1b5e20; border: 1px solid #a5d6a7; }
.gz-service__form-msg--error   { background: #ffebee; color: #b71c1c; border: 1px solid #ef9a9a; }

/* Responsive */
@media screen and (max-width: 1023px) {
	.gz-service__container { grid-template-columns: 1fr; gap: 40px; padding: 0 24px; }
	.gz-service__hero-inner { padding: 0 24px; }
	.gz-service__sidebar { position: static; }
	.gz-service__layout { padding: 48px 0 72px; }
	.gz-service__hero { padding: calc(80px + 56px) 0 56px; }
}

@media screen and (max-width: 640px) {
	.gz-service__hero { padding: calc(80px + 40px) 0 48px; }
	.gz-service__hero-inner { padding: 0 16px; }
	.gz-service__container { padding: 0 16px; }
	.gz-service__layout { padding: 32px 0 56px; }
	.gz-service__panel-price-amount { font-size: 1.625rem; }
}
