﻿/* OLD body rule neutralised — Academia NZ uses Inter (see below) */
body {
	font-family: 'Inter', sans-serif;
}

/*-- banner-bottom-slider --*/
.navbar-default .navbar-nav > li > a:hover {
	color: dodgerblue !important;
}

#Customer {
	width: 100%;
}

#Customer {
	padding: 60px 0 20px 0;
}

	#Customer h2 {
		text-align: center;
	}

.product-wp {
	background: #3c88af;
	padding: 3em 3em;
	color: #fff;
	text-align: center
}

	.product-wp .view {
		background: rgba(73, 169, 218, 0.66) none repeat scroll 0% 0%;
		color: rgb(255, 255, 255);
		padding: 4px 10px;
	}

.banner-bottom-slider, .gallery, .services, .about, .testimonials, .history, .typo, .contact, .single {
	padding: 0 0 0 0;
}

.banner-bottom-slider-left h3 {
	font-size: 1.93em;
	color: #222;
	margin: 0;
	line-height: 1.5em;
}

	.banner-bottom-slider-left h3 span {
		display: block;
		font-size: 1.5em;
		color: #5A9BDC;
		margin: .3em 0 0.5em;
	}

.banner-bottom-slider-right1 ul {
	padding: 1.5em .5em;
	background: #3598DC;
}

	.banner-bottom-slider-right1 ul li {
		display: inline-block;
		margin: 0;
		margin-left: 1.3em;
		float: none;
	}

		.banner-bottom-slider-right1 ul li a {
			font-size: 1.1em;
			color: #fff;
			text-decoration: none;
		}

			.banner-bottom-slider-right1 ul li a:hover {
				color: #212121;
			}

.banner-bottom-slider-text {
	top: 66px;
	position: absolute;
}

.banner-bottom-slider-right1 {
	border: 1px solid #f3f0f0;
	border-radius: 4px 4px 0 0;
	box-shadow: 0px 1px 1px 1px #ccc;
	margin: 0.7em;
}

.taxi-logo {
	height: 109px;
}

@font-face {
	font-family: 'flexslider-icon';
	src: url(fonts/flexslider-icon.eot);
	src: url('fonts/flexslider-icon.eot?#iefix') format('embedded-opentype'),url(fonts/flexslider-icon.woff) format('woff'),url(fonts/flexslider-icon.ttf) format('truetype'),url('fonts/flexslider-icon.svg#flexslider-icon') format('svg');
	font-weight: 400;
	font-style: normal
}

.flex-container a:hover, .flex-slider a:hover, .flex-container a:focus, .flex-slider a:focus {
	outline: none
}

.slides, .slides > li, .flex-control-nav, .flex-direction-nav {
	margin: 0;
	padding: 0;
	list-style: none
}

.flex-pauseplay span {
	text-transform: capitalize
}

.flexslider {
	margin: 0;
	padding: 0
}

	.flexslider .slides > li {
		display: none;
		-webkit-backface-visibility: hidden;
		height: 100%;
		transform: translate3d(0,0,0);
		overflow: hidden
	}

	.flexslider li > img, .flexslider li > a > img {
		width: 100%;
		display: block
	}

	.flexslider .slides:after {
		content: "\0020";
		display: block;
		clear: both;
		visibility: hidden;
		line-height: 0;
		height: 0
	}

html[xmlns] .flexslider .slides {
	display: block
}

* html .flexslider .slides {
	height: 1%
}

.no-js .flexslider .slides > li:first-child {
	display: block
}

.flexslider {
	margin: 0 0 23px 0;
	margin-bottom: 33px !important;
	position: relative;
	border-radius: 4px
}

	.flexslider.no-navs {
		margin-bottom: 0 !important
	}

	.flexslider .slides img {
		height: auto;
		max-width: none
	}

.flex-direction-nav a {
	text-decoration: none;
	display: block;
	margin: -29px 10px 0 10px;
	position: absolute;
	top: 50%;
	z-index: 10;
	overflow: hidden;
	opacity: 0;
	cursor: pointer;
	color: rgb(80,80,80);
	transition: all 0.3s ease-in-out;
	width: 60px;
	height: 57px
}

	.flex-direction-nav a:before {
		font-family: "FontAwesome";
		font-size: 55px;
		line-height: 55px;
		display: inline-block;
		color: #333;
		text-shadow: 0 0 2px #FFF
	}

.flex-direction-nav .flex-prev {
	left: -50px
}

.flex-direction-nav .flex-next {
	right: -50px
}

.flexslider:hover .flex-direction-nav .flex-prev {
	opacity: 1;
	left: 0
}

.flexslider:hover .flex-direction-nav .flex-next {
	opacity: 1;
	right: 0
}

.flex-control-nav {
	width: 100%;
	position: absolute;
	bottom: -40px;
	text-align: center;
	z-index: 9;
	height: auto !important
}

	.flex-control-nav li {
		margin: 0 6px;
		display: inline-block;
		zoom: 1;
		height: auto !important
	}

.flex-control-paging li a {
	width: 11px;
	height: 11px !important;
	display: block;
	background: rgba(181,181,181,.9);
	cursor: pointer;
	border-radius: 20px
}

	.flex-control-paging li a:hover {
		background: rgba(134,134,134,.7)
	}

	.flex-control-paging li a.flex-active {
		background: #DCDCDC;
		cursor: default;
		opacity: 1
	}

.flexslider .slides > li {
	display: block
}

.anima {
	color: #46C6F4
}

.text-m {
	color: #EFEEF4 !important
}

.text-mm {
	color: #000 !important
}

.text_color {
	color: #4D4D4D
}

.box_color {
	background-color: #EAEAEB !important
}

.no-paddings-y {
	padding-top: 40px !important
}

.section-bg-color {
	background-color: #fff !important
}

.section-bg-colorr {
	background-color: #eeeeee !important
}

.block_grey {
	background: #eaeaeb !important
}

.container.content {
	padding-top: 40px !important
}

.img-box:before {
	opacity: 0 !important
}

.logo_heading {
	margin: 15px 0px !important
}

.navbar-brand img {
	margin-top: 6px
}

.box_color2 {
	background: #23A9E6 !important
}

.navbar-default .navbar-brand {
	color: #000000 !important
}

.btn-search {
	padding: 18px 15px 18px 15px
}

.white.btn {
	background: #676a6b !important
}

.list-nav {
	padding: 60px
}

.box_color_blue {
	background-color: #1f9ccf !important
}

	.box_color_blue:hover {
		background-color: #eaeaeb !important
	}

.services_button {
	padding: 0px !important
}

.title-base {
	margin-bottom: 0px !important
}

.boxed-inverse {
	background-color: #fff
}

.form-control {
	background: #fff !important
}

.gallery {
	padding: 0px !important
}

.grid-box.row {
	margin-top: 15px !important;
	margin-bottom: 40px !important
}

.nbs-flexisel-nav-left {
	left: -38px !important
}

#map {
	width: 100%;
	height: 600px;
	background-color: grey
}

.btn {
	font-size: 15px
}

.footer_font {
	font-size: 19px
}

.content {
	padding-bottom: 1px !important
}

.button_web {
	padding: 15px 40px !important
}

.webservice_block {
	padding: 40px !important
}

@media (max-width: 681px) {
	.footer_center {
		text-align: center
	}
}

@media (min-width: 768px) {
	.footer-base .social-group {
		display: -webkit-inline-box
	}
}

@media (min-width: 992px) {
	/* col-md padding override removed — was conflicting with footer grid */
	.header .navbar-nav > li > a, .navbar-default .navbar-nav > li > a {
		padding: 0 15px 19px 15px !important;
		padding-top: 23px !important
	}
}

@media (max-width: 600px) {
	/* col-md 600px width overrides removed — were conflicting */
	.maso-box > .maso-item, .grid-box > .grid-item {
		padding: 10px
	}
}

@media (max-width: 992px) {
	.menu-transparent .navbar-collapse {
		background-color: #C0C0C0 !important
	}

	.niche-box-team .content-box {
		overflow: initial !important
	}

	header button.navbar-toggle {
		margin: 30px 6px 0 6px !important
	}
}

@media (max-width: 450px) {
	.circle-button {
		margin-bottom: 15px
	}
}

@media (max-width: 480px) {
	.footer-grid {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.footer-brand {
		text-align: center;
	}

	.footer-social {
		justify-content: center;
	}

	.footer-col {
		text-align: center;
	}

	.footer-bottom {
		font-size: 0.78rem;
	}
}


/* =============================================================
   ACADEMIA NEW ZEALAND — GLOBAL STYLES
   Navbar, Footer, and all page section styles
   ============================================================= */

/* ── CSS Variables ── */
:root {
	--primary: #1e3a5f;
	--secondary: #d4af37;
	--accent: #ff6b6b;
	--nz-green: #2d5a27;
	--nz-blue: #0052cc;
	--light: #f8fafc;
	--dark: #1a202c;
	--text: #4a5568;
	--white: #ffffff;
	--gradient: linear-gradient(135deg, #1e3a5f 0%, #2c5282 100%);
	--nz-gradient: linear-gradient(135deg, #1e3a5f 0%, #2d5a27 100%);
}


/* ─────────────────────────────────────────
   CRITICAL OVERRIDES
   Neutralise legacy CSS rules in style.css /
   mainstyle.css that break specific pages.
───────────────────────────────────────── */

/* style.css / mainstyle.css has:
   #contact { width: 50% !important; float: right !important }
   This breaks the homepage CTA section (id="contact") AND
   Terms section 15 (id="contact").
   Override here so it wins regardless of load order.          */
#contact {
	width: 100% !important;
	float: none !important;
	clear: both;
	box-sizing: border-box;
}

/* Belt-and-braces: reset any float on ALL direct section children
   so a rogue float in external CSS can never push the footer sideways */
main section,
main article,
main > div {
	float: none !important;
	clear: both;
	width: 100% !important;
	max-width: 100%;
	box-sizing: border-box;
}

/* Clearfix on main so floated children don't collapse its height */
main::after {
	content: '';
	display: table;
	clear: both;
}

/* ── Base reset for Academia pages ── */
body {
	font-family: 'Inter', sans-serif !important;
	color: var(--text);
	line-height: 1.6;
	overflow-x: hidden;
	padding-top: 80px; /* offset for fixed navbar */
	display: flex;
	flex-direction: column;
	min-height: 100vh; /* footer always at bottom */
}

/* Stretch main content so footer is always pushed to bottom
   on short pages (Cookies, Disclaimer, Terms etc.) */
main {
	flex: 1 0 auto;
}

h1, h2, h3, h4 {
	font-family: 'Playfair Display', serif;
	color: var(--primary);
	font-weight: 600;
}

/* ─────────────────────────────────────────
   NAVBAR
───────────────────────────────────────── */
#mainNavbar {
	position: fixed;
	top: 0;
	width: 100%;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	z-index: 1000;
	padding: 1rem 5%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-shadow: 0 2px 20px rgba(0,0,0,0.05);
	transition: all 0.3s ease;
}

.navbar-logo {
	display: flex;
	align-items: center;
	text-decoration: none;
}

	.navbar-logo img {
		height: 75px;
		width: auto;
	}

#mainNavbar .nav-links {
	display: flex;
	gap: 2.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

	#mainNavbar .nav-links a {
		text-decoration: none;
		color: var(--dark);
		font-family: 'Inter', sans-serif;
		font-weight: 500;
		font-size: 0.95rem;
		position: relative;
		transition: color 0.3s;
	}

		#mainNavbar .nav-links a::after {
			content: '';
			position: absolute;
			bottom: -5px;
			left: 0;
			width: 0;
			height: 2px;
			background: var(--nz-green);
			transition: width 0.3s;
		}

		#mainNavbar .nav-links a:hover {
			color: var(--nz-green);
		}

			#mainNavbar .nav-links a:hover::after {
				width: 100%;
			}

.nav-cta {
	background: var(--nz-gradient);
	color: white !important;
	padding: 0.8rem 1.8rem;
	border-radius: 30px;
	text-decoration: none;
	font-family: 'Inter', sans-serif;
	font-weight: 600;
	font-size: 0.9rem;
	transition: transform 0.3s, box-shadow 0.3s;
	white-space: nowrap;
}

	.nav-cta:hover {
		transform: translateY(-2px);
		box-shadow: 0 10px 30px rgba(30, 58, 95, 0.3);
	}

/* Hamburger */
.nav-hamburger {
	display: none;
	flex-direction: column;
	gap: 5px;
	cursor: pointer;
	background: none;
	border: none;
	padding: 4px;
}

	.nav-hamburger span {
		width: 25px;
		height: 3px;
		background: var(--primary);
		border-radius: 2px;
		transition: 0.3s;
		display: block;
	}

/* Offcanvas mobile nav */
.offcanvas-body .navbar-nav {
	padding: 1rem 0;
}

.offcanvas-body .nav-link {
	font-family: 'Inter', sans-serif;
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--dark);
	padding: 0.75rem 0;
	border-bottom: 1px solid rgba(0,0,0,0.06);
	transition: color 0.2s;
}

	.offcanvas-body .nav-link:hover {
		color: var(--nz-green);
	}

.nav-cta-mobile {
	display: inline-block;
	margin-top: 1.5rem;
	background: var(--nz-gradient);
	color: white;
	padding: 0.9rem 2rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	font-size: 0.95rem;
	text-align: center;
}

/* ─────────────────────────────────────────
   HERO SECTION
───────────────────────────────────────── */
.hero {
	min-height: 90vh;
	background: linear-gradient(135deg, #1e3a5f 0%, #2d5a27 50%, #1e3a5f 100%);
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
}

	.hero::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M50 0 C60 20, 80 20, 100 50 C80 80, 60 80, 50 100 C40 80, 20 80, 0 50 C20 20, 40 20, 50 0' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E");
		background-size: 200px;
		opacity: 0.5;
	}

.hero-pattern {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: radial-gradient(circle at 20% 50%, rgba(212, 175, 55, 0.15) 0%, transparent 50%), radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.05) 0%, transparent 50%);
	animation: nz-pulse 15s ease-in-out infinite;
}

@keyframes nz-pulse {
	0%, 100% {
		opacity: 0.5;
	}

	50% {
		opacity: 1;
	}
}

.hero-content {
	position: relative;
	z-index: 2;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 5%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: center;
}

.hero-text h1 {
	font-size: 4rem;
	color: white;
	line-height: 1.1;
	margin-bottom: 1.5rem;
	animation: nz-fadeInUp 1s ease;
}

	.hero-text h1 span {
		color: var(--secondary);
		display: block;
	}

.hero-text p {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: 2rem;
	max-width: 500px;
	animation: nz-fadeInUp 1s ease 0.2s backwards;
}

.hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: rgba(255,255,255,0.15);
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-size: 0.9rem;
	color: white;
	margin-bottom: 1.5rem;
	backdrop-filter: blur(10px);
	animation: nz-fadeInUp 1s ease 0.1s backwards;
}

.hero-stats {
	display: flex;
	gap: 3rem;
	margin-top: 3rem;
	animation: nz-fadeInUp 1s ease 0.4s backwards;
}

.stat {
	text-align: center;
}

.stat-number {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--secondary);
	display: block;
}

.stat-label {
	color: rgba(255, 255, 255, 0.8);
	font-size: 0.9rem;
}

.hero-visual {
	position: relative;
	animation: nz-float 6s ease-in-out infinite;
}

@keyframes nz-float {
	0%, 100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-20px);
	}
}

.hero-image {
	width: 100%;
	height: 500px;
	background: linear-gradient(45deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05));
	border-radius: 20px;
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255,255,255,0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}

	.hero-image::before {
		content: '🌿';
		font-size: 8rem;
		opacity: 0.3;
	}

.floating-card {
	position: absolute;
	background: white;
	padding: 1rem 1.5rem;
	border-radius: 12px;
	box-shadow: 0 20px 40px rgba(0,0,0,0.1);
	animation: nz-floatCard 4s ease-in-out infinite;
}

	.floating-card:nth-child(2) {
		top: 10%;
		right: -20px;
		animation-delay: 0.5s;
	}

	.floating-card:nth-child(3) {
		bottom: 20%;
		left: -30px;
		animation-delay: 1s;
	}

@keyframes nz-floatCard {
	0%, 100% {
		transform: translateY(0) rotate(0deg);
	}

	50% {
		transform: translateY(-10px) rotate(2deg);
	}
}

.cta-group {
	display: flex;
	gap: 1rem;
	animation: nz-fadeInUp 1s ease 0.6s backwards;
}

.btn-primary {
	background: var(--secondary);
	color: var(--primary);
	padding: 1rem 2.5rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	transition: all 0.3s;
	border: none;
	cursor: pointer;
}

	.btn-primary:hover {
		transform: translateY(-3px);
		box-shadow: 0 15px 40px rgba(212, 175, 55, 0.4);
		color: var(--primary);
	}

.btn-secondary {
	background: transparent;
	color: white;
	padding: 1rem 2.5rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	border: 2px solid rgba(255,255,255,0.3);
	transition: all 0.3s;
}

	.btn-secondary:hover {
		background: white;
		color: var(--primary);
	}

@keyframes nz-fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ─────────────────────────────────────────
   SHARED SECTION STYLES
───────────────────────────────────────── */
.section-header {
	text-align: center;
	max-width: 700px;
	margin: 0 auto 4rem;
}

	.section-header h2 {
		font-size: 3rem;
		margin-bottom: 1rem;
	}

	.section-header p {
		font-size: 1.1rem;
		color: var(--text);
	}

/* Scroll fade-in */
.fade-in {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.8s, transform 0.8s;
}

	.fade-in.visible {
		opacity: 1;
		transform: translateY(0);
	}

/* ─────────────────────────────────────────
   WHY NEW ZEALAND
───────────────────────────────────────── */
.why-nz {
	padding: 6rem 5%;
	background: var(--light);
}

.nz-features {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	max-width: 1400px;
	margin: 0 auto;
}

.nz-feature-card {
	background: white;
	padding: 2.5rem;
	border-radius: 20px;
	box-shadow: 0 10px 40px rgba(0,0,0,0.08);
	transition: all 0.4s;
	position: relative;
	overflow: hidden;
}

	.nz-feature-card::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 5px;
		background: var(--nz-gradient);
		transform: scaleX(0);
		transition: transform 0.4s;
	}

	.nz-feature-card:hover::before {
		transform: scaleX(1);
	}

	.nz-feature-card:hover {
		transform: translateY(-10px);
		box-shadow: 0 30px 60px rgba(0,0,0,0.12);
	}

.feature-icon {
	width: 70px;
	height: 70px;
	background: var(--nz-gradient);
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 2rem;
	margin-bottom: 1.5rem;
}

.nz-feature-card h3 {
	font-size: 1.4rem;
	margin-bottom: 1rem;
}

.nz-feature-card p {
	color: var(--text);
	line-height: 1.8;
}

.nz-trusted {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: rgba(45, 90, 39, 0.1);
	color: var(--nz-green);
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 600;
	margin-top: 1rem;
}

/* ─────────────────────────────────────────
   UNIVERSITIES
───────────────────────────────────────── */
.universities {
	padding: 6rem 5%;
	background: white;
}

.universities-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 2rem;
	max-width: 1400px;
	margin: 0 auto;
}

.university-card {
	background: white;
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 10px 40px rgba(0,0,0,0.08);
	transition: all 0.4s;
	border: 1px solid rgba(0,0,0,0.05);
}

	.university-card:hover {
		transform: translateY(-10px);
		box-shadow: 0 30px 60px rgba(0,0,0,0.12);
	}

.university-header {
	height: 150px;
	background: var(--nz-gradient);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.university-rank {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: var(--secondary);
	color: var(--primary);
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-weight: 700;
	font-size: 0.9rem;
}

.university-logo {
	width: 80px;
	height: 80px;
	background: white;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	font-weight: 700;
	box-shadow: 0 10px 30px rgba(0,0,0,0.2);
	color: var(--primary);
}

.university-content {
	padding: 2rem;
}

	.university-content h3 {
		font-size: 1.5rem;
		margin-bottom: 0.5rem;
	}

.university-location {
	color: var(--nz-green);
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 1rem;
}

.university-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 1rem;
}

.tag {
	background: var(--light);
	padding: 0.4rem 0.8rem;
	border-radius: 15px;
	font-size: 0.85rem;
	color: var(--dark);
}

/* ─────────────────────────────────────────
   VISA PATHWAYS
───────────────────────────────────────── */
.visa-section {
	padding: 6rem 5%;
	background: var(--primary);
	color: white;
	position: relative;
	overflow: hidden;
}

	.visa-section::before {
		content: '';
		position: absolute;
		top: -50%;
		right: -20%;
		width: 600px;
		height: 600px;
		background: rgba(212, 175, 55, 0.1);
		border-radius: 50%;
	}

	.visa-section h2 {
		color: white;
		text-align: center;
		font-size: 3rem;
		margin-bottom: 4rem;
	}

.visa-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	max-width: 1400px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}

.visa-card {
	background: rgba(255,255,255,0.1);
	backdrop-filter: blur(10px);
	padding: 2.5rem;
	border-radius: 20px;
	border: 1px solid rgba(255,255,255,0.2);
	transition: all 0.4s;
}

	.visa-card:hover {
		background: rgba(255,255,255,0.15);
		transform: translateY(-5px);
	}

.visa-icon {
	font-size: 3rem;
	margin-bottom: 1rem;
}

.visa-card h3 {
	color: white;
	font-size: 1.4rem;
	margin-bottom: 1rem;
}

.visa-card p {
	color: rgba(255,255,255,0.9);
	line-height: 1.8;
	margin-bottom: 1.5rem;
}

.visa-highlight {
	background: var(--secondary);
	color: var(--primary);
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-weight: 600;
	font-size: 0.9rem;
	display: inline-block;
}

/* ─────────────────────────────────────────
   SERVICES
───────────────────────────────────────── */
.services {
	padding: 6rem 5%;
	background: var(--light);
}

.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 2.5rem;
	max-width: 1400px;
	margin: 0 auto;
}

.service-card {
	padding: 3rem;
	border-radius: 20px;
	background: white;
	transition: all 0.4s;
	position: relative;
	overflow: hidden;
	box-shadow: 0 10px 40px rgba(0,0,0,0.05);
}

	.service-card::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 5px;
		background: var(--nz-gradient);
		transform: scaleX(0);
		transition: transform 0.4s;
	}

	.service-card:hover::before {
		transform: scaleX(1);
	}

	.service-card:hover {
		transform: translateY(-5px);
		box-shadow: 0 20px 40px rgba(0,0,0,0.1);
	}

.service-icon {
	width: 70px;
	height: 70px;
	background: var(--nz-gradient);
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 2rem;
	margin-bottom: 1.5rem;
}

.service-card h3 {
	font-size: 1.5rem;
	margin-bottom: 1rem;
}

.service-card p {
	color: var(--text);
	line-height: 1.8;
}

/* ─────────────────────────────────────────
   PROCESS
───────────────────────────────────────── */
.process {
	padding: 6rem 5%;
	background: white;
}

	.process h2 {
		text-align: center;
		font-size: 3rem;
		margin-bottom: 4rem;
	}

.process-steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	max-width: 1400px;
	margin: 0 auto;
	position: relative;
}

	.process-steps::before {
		content: '';
		position: absolute;
		top: 40px;
		left: 12.5%;
		right: 12.5%;
		height: 2px;
		background: linear-gradient(to right, var(--primary), var(--nz-green));
		z-index: 0;
	}

.step {
	text-align: center;
	position: relative;
	z-index: 1;
}

.step-number {
	width: 80px;
	height: 80px;
	background: var(--nz-gradient);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	font-weight: 700;
	margin: 0 auto 1.5rem;
	color: white;
	box-shadow: 0 10px 30px rgba(30, 58, 95, 0.3);
}

.step h3 {
	color: var(--primary);
	font-size: 1.3rem;
	margin-bottom: 0.5rem;
}

.step p {
	color: var(--text);
	font-size: 0.95rem;
}

/* ─────────────────────────────────────────
   COST SECTION
───────────────────────────────────────── */
.cost-section {
	padding: 6rem 5%;
	background: linear-gradient(135deg, #f8fafc 0%, #e6fffa 100%);
}

.cost-container {
	max-width: 1000px;
	margin: 0 auto;
	background: white;
	padding: 3rem;
	border-radius: 20px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.1);
}

.cost-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	margin-top: 2rem;
}

.cost-item {
	text-align: center;
	padding: 2rem;
	background: var(--light);
	border-radius: 15px;
	transition: all 0.3s;
}

	.cost-item:hover {
		transform: translateY(-5px);
		background: white;
		box-shadow: 0 10px 30px rgba(0,0,0,0.1);
	}

.cost-amount {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--nz-green);
	display: block;
}

.cost-label {
	color: var(--text);
	font-size: 0.95rem;
	margin-top: 0.5rem;
}

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
.testimonials {
	padding: 6rem 5%;
	background: white;
}

.testimonials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 2rem;
	max-width: 1400px;
	margin: 0 auto;
}

.testimonial-card {
	background: var(--light);
	padding: 2.5rem;
	border-radius: 20px;
	position: relative;
	transition: all 0.4s;
}

	.testimonial-card:hover {
		transform: translateY(-5px);
		box-shadow: 0 20px 40px rgba(0,0,0,0.1);
	}

	.testimonial-card::before {
		content: '"';
		position: absolute;
		top: 20px;
		right: 30px;
		font-size: 6rem;
		color: var(--nz-green);
		opacity: 0.2;
		font-family: serif;
	}

.stars {
	color: var(--secondary);
	margin-bottom: 1rem;
	font-size: 1.2rem;
}

.testimonial-text {
	font-size: 1.1rem;
	color: var(--dark);
	margin-bottom: 1.5rem;
	line-height: 1.8;
}

.testimonial-author {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.author-avatar {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: var(--nz-gradient);
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 600;
}

.author-info h4 {
	color: var(--primary);
	font-size: 1.1rem;
}

.author-info p {
	color: var(--text);
	font-size: 0.9rem;
}

.nz-badge {
	display: inline-block;
	background: var(--nz-green);
	color: white;
	padding: 0.3rem 0.8rem;
	border-radius: 15px;
	font-size: 0.8rem;
	margin-top: 0.5rem;
}

/* ─────────────────────────────────────────
   CTA SECTION
───────────────────────────────────────── */
.cta-section {
	padding: 6rem 5%;
	background: var(--nz-gradient);
	text-align: center;
	position: relative;
	overflow: hidden;
}

	.cta-section::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
	}

.cta-content {
	position: relative;
	z-index: 1;
	max-width: 800px;
	margin: 0 auto;
}

.cta-section h2 {
	color: white;
	font-size: 3rem;
	margin-bottom: 1.5rem;
}

.cta-section p {
	color: rgba(255,255,255,0.9);
	font-size: 1.2rem;
	margin-bottom: 2.5rem;
}

.cta-buttons {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* ─────────────────────────────────────────
   GLOBAL FOOTER
───────────────────────────────────────── */
.site-footer {
	background: var(--dark);
	color: white;
	padding: 4rem 5% 2rem;
	font-family: 'Inter', sans-serif;
	flex-shrink: 0; /* never shrink in flex body */
	width: 100%;
	box-sizing: border-box;
}

.footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
	gap: 2.5rem;
	max-width: 1400px;
	margin: 0 auto 2.5rem;
	align-items: start; /* all cols align from top */
}

.footer-brand img {
	height: 80px;
	width: auto;
	margin-bottom: 1rem;
	display: block;
}

.footer-brand h3 {
	font-family: 'Playfair Display', serif;
	color: white;
	font-size: 1.4rem;
	margin-bottom: 0.75rem;
}

.footer-brand > p {
	color: rgba(255,255,255,0.7);
	font-size: 0.88rem;
	line-height: 1.75;
	margin-bottom: 1.5rem;
}

.footer-social {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

	.footer-social a {
		width: 38px;
		height: 38px;
		background: rgba(255,255,255,0.1);
		border-radius: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		color: white;
		text-decoration: none;
		font-size: 0.88rem;
		transition: all 0.3s;
		flex-shrink: 0;
	}

		.footer-social a:hover {
			background: var(--secondary);
			color: var(--primary);
			transform: translateY(-3px);
		}

.footer-col h4 {
	font-family: 'Playfair Display', serif;
	color: white;
	font-size: 1rem;
	margin-bottom: 1.2rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}

.footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-col li {
	margin-bottom: 0.65rem;
}

.footer-col a {
	color: rgba(255,255,255,0.65);
	text-decoration: none;
	font-size: 0.875rem;
	font-family: 'Inter', sans-serif;
	transition: color 0.25s;
	line-height: 1.5;
}

	.footer-col a:hover {
		color: var(--secondary);
	}

.footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.1);
	padding-top: 1.75rem;
	margin-top: 0;
	text-align: center;
	color: rgba(255,255,255,0.45);
	font-size: 0.82rem;
	font-family: 'Inter', sans-serif;
	max-width: 1400px;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.7;
}

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 1024px) {
	.hero-content {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.hero-text h1 {
		font-size: 3rem;
	}

	.hero-stats {
		justify-content: center;
	}

	.process-steps {
		grid-template-columns: repeat(2, 1fr);
	}

		.process-steps::before {
			display: none;
		}

	.cost-grid {
		grid-template-columns: 1fr;
	}

	.footer-grid {
		grid-template-columns: 1fr 1fr 1fr;
		gap: 2rem;
	}

	.footer-brand {
		grid-column: 1 / -1;
	}
	/* brand spans full width on tablet */
}

@media (max-width: 768px) {
	#mainNavbar .nav-links,
	.nav-cta {
		display: none;
	}

	.nav-hamburger {
		display: flex;
	}

	#mainNavbar {
		padding: 0.8rem 5%;
	}

	.hero-text h1 {
		font-size: 2.5rem;
	}

	.process-steps {
		grid-template-columns: 1fr;
	}

	.footer-grid {
		grid-template-columns: 1fr 1fr;
		gap: 2rem;
		text-align: left;
	}

	.footer-brand {
		grid-column: 1 / -1;
		text-align: center;
	}

	.footer-social {
		justify-content: center;
	}

	.cta-buttons {
		flex-direction: column;
		align-items: center;
	}
}


/* =============================================================
   STATIC PAGES — FAQ, Terms, Privacy, Cookies, Disclaimer, Resources
   ============================================================= */

/* ── Page Hero (shared across all static pages) ── */
.page-hero {
	padding: 4rem 5%;
	background: var(--nz-gradient);
	text-align: center;
	color: white;
}

	.page-hero h1 {
		font-family: 'Playfair Display', serif;
		font-size: clamp(2rem, 4vw, 3rem);
		color: white;
		margin-bottom: 1rem;
		font-weight: 600;
	}

	.page-hero p {
		font-size: 1.1rem;
		color: rgba(255,255,255,0.9);
		max-width: 700px;
		margin: 0 auto;
		line-height: 1.75;
	}

/* ── Page CTA ── */
.page-cta-section {
	padding: 4rem 5%;
	background: var(--nz-gradient);
	text-align: center;
}

	.page-cta-section h2 {
		font-family: 'Playfair Display', serif;
		color: white;
		font-size: 2rem;
		margin-bottom: 1rem;
	}

	.page-cta-section p {
		color: rgba(255,255,255,0.9);
		margin-bottom: 2rem;
		font-size: 1.05rem;
	}

/* ── Content Section (Privacy, Terms, Cookies, Disclaimer) ── */
.content-section {
	padding: 4rem 5%;
	max-width: 960px;
	margin: 0 auto;
}

.content-box {
	background: white;
	padding: 3rem;
	border-radius: 16px;
	box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

.last-updated {
	text-align: center;
	color: #718096;
	font-size: 0.9rem;
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid #e2e8f0;
}

.content-box .section {
	margin-bottom: 2.5rem;
}

	.content-box .section h2 {
		font-family: 'Playfair Display', serif;
		font-size: 1.35rem;
		color: var(--primary);
		margin-bottom: 1rem;
		padding-bottom: 0.5rem;
		border-bottom: 2px solid var(--secondary);
	}

	.content-box .section h3 {
		font-family: 'Playfair Display', serif;
		font-size: 1.05rem;
		color: var(--primary);
		margin: 1.2rem 0 0.6rem;
	}

	.content-box .section p {
		color: var(--text);
		line-height: 1.8;
		margin-bottom: 0.75rem;
	}

	.content-box .section ul,
	.content-box .section ol {
		margin: 0.75rem 0 0.75rem 1.5rem;
	}

	.content-box .section li {
		color: var(--text);
		line-height: 1.75;
		margin-bottom: 0.4rem;
	}

	.content-box .section a {
		color: var(--primary);
		text-decoration: underline;
	}

		.content-box .section a:hover {
			color: var(--nz-green);
		}

/* Highlight box */
.highlight-box {
	background: rgba(30, 58, 95, 0.05);
	border-left: 4px solid var(--primary);
	padding: 1.2rem 1.5rem;
	border-radius: 0 8px 8px 0;
	margin: 1.2rem 0;
}

	.highlight-box p {
		color: var(--text);
		line-height: 1.75;
		margin: 0;
	}

	.highlight-box a {
		color: var(--primary);
	}

/* Warning box */
.warning-box {
	background: rgba(255, 107, 107, 0.06);
	border-left: 4px solid var(--accent);
	padding: 1.2rem 1.5rem;
	border-radius: 0 8px 8px 0;
	margin: 1.2rem 0;
}

	.warning-box p {
		color: var(--text);
		line-height: 1.75;
		margin: 0;
	}

/* Table of Contents */
.toc {
	background: var(--light);
	padding: 1.8rem 2rem;
	border-radius: 12px;
	margin-bottom: 2.5rem;
	border: 1px solid #e2e8f0;
}

	.toc h3 {
		font-family: 'Playfair Display', serif;
		color: var(--primary);
		font-size: 1.1rem;
		margin-bottom: 1rem;
	}

	.toc ul {
		list-style: none;
		padding: 0;
		margin: 0;
		columns: 2;
		column-gap: 2rem;
	}

	.toc li {
		margin-bottom: 0.5rem;
	}

	.toc a {
		color: var(--primary);
		text-decoration: none;
		font-size: 0.92rem;
		transition: color 0.2s;
	}

		.toc a:hover {
			color: var(--nz-green);
		}

/* Cookie table */
.cookie-table {
	width: 100%;
	border-collapse: collapse;
	margin-top: 1rem;
	font-size: 0.9rem;
}

	.cookie-table th {
		background: var(--primary);
		color: white;
		padding: 0.75rem 1rem;
		text-align: left;
		font-family: 'Inter', sans-serif;
		font-weight: 600;
	}

	.cookie-table td {
		padding: 0.75rem 1rem;
		border-bottom: 1px solid #e2e8f0;
		color: var(--text);
		vertical-align: top;
	}

	.cookie-table tr:nth-child(even) td {
		background: var(--light);
	}

	.cookie-table tr:hover td {
		background: rgba(30, 58, 95, 0.04);
	}

/* ── FAQ Section ── */
.search-section {
	padding: 2rem 5%;
	background: white;
	border-bottom: 1px solid #e2e8f0;
}

.search-container {
	max-width: 700px;
	margin: 0 auto;
	position: relative;
}

.search-input {
	width: 100%;
	padding: 1rem 1.5rem 1rem 3rem;
	border: 2px solid #e2e8f0;
	border-radius: 50px;
	font-size: 1rem;
	font-family: 'Inter', sans-serif;
	transition: all 0.3s;
	color: var(--dark);
}

	.search-input:focus {
		outline: none;
		border-color: var(--primary);
		box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.1);
	}

.search-icon {
	position: absolute;
	left: 1.25rem;
	top: 50%;
	transform: translateY(-50%);
	color: #718096;
	pointer-events: none;
}

.faq-section {
	padding: 4rem 5%;
	max-width: 1020px;
	margin: 0 auto;
}

.faq-categories {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 3rem;
}

.faq-category {
	padding: 0.65rem 1.4rem;
	background: white;
	border: 2px solid #e2e8f0;
	border-radius: 30px;
	cursor: pointer;
	font-weight: 500;
	font-size: 0.9rem;
	font-family: 'Inter', sans-serif;
	color: var(--dark);
	transition: all 0.3s;
}

	.faq-category:hover,
	.faq-category.active {
		background: var(--nz-gradient);
		color: white;
		border-color: transparent;
	}

.faq-item {
	background: white;
	border-radius: 12px;
	margin-bottom: 0.85rem;
	box-shadow: 0 2px 10px rgba(0,0,0,0.05);
	overflow: hidden;
	transition: box-shadow 0.3s;
}

	.faq-item:hover {
		box-shadow: 0 4px 20px rgba(0,0,0,0.09);
	}

.faq-question {
	padding: 1.4rem 1.6rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	transition: background 0.3s;
}

	.faq-question:hover {
		background: var(--light);
	}

	.faq-question h3 {
		font-family: 'Inter', sans-serif;
		font-size: 1rem;
		color: var(--dark);
		font-weight: 600;
		padding-right: 2rem;
		margin: 0;
	}

.faq-icon {
	font-size: 1.4rem;
	color: var(--primary);
	transition: transform 0.3s;
	flex-shrink: 0;
	line-height: 1;
}

.faq-item.active .faq-icon {
	transform: rotate(45deg);
}

.faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.4s ease, padding 0.3s ease;
}

.faq-item.active .faq-answer {
	max-height: 1000px;
	padding: 0 1.6rem 1.6rem;
}

.faq-answer p {
	color: var(--text);
	line-height: 1.8;
	margin-bottom: 0.7rem;
}

.faq-answer ul, .faq-answer ol {
	margin: 0.7rem 0 0.7rem 1.5rem;
}

.faq-answer li {
	color: var(--text);
	line-height: 1.75;
	margin-bottom: 0.4rem;
}

.faq-answer strong {
	color: var(--primary);
}

.faq-answer a {
	color: var(--primary);
}

.hidden {
	display: none !important;
}

/* ── Resources Section ── */
.resources-section {
	padding: 3rem 5% 5rem;
	max-width: 1400px;
	margin: 0 auto;
}

.quick-links {
	background: var(--light);
	padding: 2rem 2.5rem;
	border-radius: 16px;
	margin-bottom: 3rem;
	border: 1px solid #e2e8f0;
}

	.quick-links h3 {
		font-family: 'Playfair Display', serif;
		color: var(--primary);
		font-size: 1.2rem;
		margin-bottom: 1.2rem;
	}

.quick-links-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.quick-link {
	padding: 0.6rem 1.2rem;
	background: white;
	border: 2px solid #e2e8f0;
	border-radius: 25px;
	color: var(--dark);
	text-decoration: none;
	font-size: 0.88rem;
	font-weight: 500;
	transition: all 0.25s;
}

	.quick-link:hover {
		background: var(--primary);
		color: white;
		border-color: var(--primary);
		transform: translateY(-2px);
	}

.featured-section {
	margin-bottom: 3rem;
}

	.featured-section h2 {
		font-family: 'Playfair Display', serif;
		font-size: 1.6rem;
		color: var(--primary);
		margin-bottom: 1.5rem;
	}

.featured-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.4rem;
}

.featured-item {
	background: white;
	padding: 2rem 1.8rem;
	border-radius: 16px;
	border: 1px solid #e2e8f0;
	text-align: center;
	box-shadow: 0 4px 16px rgba(0,0,0,0.06);
	transition: transform 0.3s, box-shadow 0.3s;
}

	.featured-item:hover {
		transform: translateY(-6px);
		box-shadow: 0 16px 40px rgba(0,0,0,0.1);
	}

.featured-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
}

.featured-item h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.1rem;
	color: var(--primary);
	margin-bottom: 0.6rem;
}

.featured-item p {
	color: var(--text);
	font-size: 0.88rem;
	line-height: 1.65;
	margin-bottom: 1.2rem;
}

.btn-featured {
	display: inline-block;
	padding: 0.55rem 1.3rem;
	background: var(--nz-gradient);
	color: white;
	border-radius: 25px;
	text-decoration: none;
	font-size: 0.85rem;
	font-weight: 600;
	transition: opacity 0.25s, transform 0.25s;
}

	.btn-featured:hover {
		opacity: 0.9;
		transform: translateY(-1px);
	}

.resource-category {
	margin-bottom: 3rem;
}

.category-header {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.4rem;
	padding-bottom: 0.8rem;
	border-bottom: 2px solid var(--secondary);
}

.category-icon {
	font-size: 1.6rem;
}

.category-header h2 {
	font-family: 'Playfair Display', serif;
	font-size: 1.5rem;
	color: var(--primary);
	margin: 0;
}

.resources-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.2rem;
}

.resource-card {
	background: white;
	padding: 1.6rem;
	border-radius: 12px;
	border: 1px solid #e2e8f0;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
	box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

	.resource-card:hover {
		transform: translateY(-4px);
		box-shadow: 0 12px 32px rgba(0,0,0,0.1);
		border-color: var(--primary);
	}

.resource-tag {
	display: inline-block;
	padding: 0.25rem 0.7rem;
	background: var(--nz-gradient);
	color: white;
	border-radius: 20px;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	margin-bottom: 0.8rem;
	align-self: flex-start;
}

.resource-card h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.05rem;
	color: var(--primary);
	margin-bottom: 0.5rem;
}

.resource-card p {
	color: var(--text);
	font-size: 0.88rem;
	line-height: 1.65;
	flex: 1;
	margin-bottom: 1rem;
}

.resource-link {
	color: var(--nz-green);
	font-weight: 600;
	font-size: 0.88rem;
	margin-top: auto;
}

/* ── Responsive for static pages ── */
@media (max-width: 768px) {
	.content-box {
		padding: 1.8rem 1.4rem;
	}

	.toc ul {
		columns: 1;
	}

	.faq-categories {
		gap: 0.5rem;
	}

	.resources-section {
		padding: 2rem 4% 4rem;
	}

	.featured-grid {
		grid-template-columns: 1fr;
	}

	.resources-grid {
		grid-template-columns: 1fr;
	}

	.quick-links {
		padding: 1.5rem;
	}
}


/* =============================================================
   APPLY PAGE
   ============================================================= */

.apply-form-section {
	padding: 4rem 5%;
	max-width: 1020px;
	margin: 0 auto;
}

.apply-form-container {
	background: white;
	padding: 3rem;
	border-radius: 20px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.1);
}

.apply-form-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

	.apply-form-header h2 {
		font-family: 'Playfair Display', serif;
		font-size: 2rem;
		color: var(--primary);
		margin-bottom: 0.5rem;
	}

	.apply-form-header p {
		color: var(--text);
	}

/* Progress Bar */
.progress-bar {
	display: flex;
	justify-content: space-between;
	margin-bottom: 3rem;
	position: relative;
}

	.progress-bar::before {
		content: '';
		position: absolute;
		top: 22px;
		left: 10%;
		right: 10%;
		height: 4px;
		background: #e2e8f0;
		z-index: 0;
	}

.progress-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	z-index: 1;
}

.progress-step-num {
	width: 44px;
	height: 44px;
	background: var(--nz-gradient);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-family: 'Inter', sans-serif;
	margin-bottom: 0.5rem;
}

.step-label {
	font-size: 0.82rem;
	color: var(--text);
	font-weight: 500;
	font-family: 'Inter', sans-serif;
}

/* Form elements */
.apply-section-title {
	font-family: 'Playfair Display', serif;
	font-size: 1.25rem;
	color: var(--primary);
	margin: 2.5rem 0 1.5rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var(--secondary);
}

.doc-subheading {
	font-size: 1rem;
	color: var(--primary);
	margin: 2rem 0 1rem;
	font-weight: 600;
	font-family: 'Inter', sans-serif;
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
}

.form-group {
	margin-bottom: 1.5rem;
}

.apply-form-container label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 500;
	color: var(--dark);
	font-size: 0.92rem;
}

.required {
	color: var(--accent);
}

.apply-form-container input[type="text"],
.apply-form-container input[type="email"],
.apply-form-container input[type="tel"],
.apply-form-container input[type="date"],
.apply-form-container input[type="number"],
.apply-form-container select,
.apply-form-container textarea {
	width: 100%;
	padding: 0.875rem 1rem;
	border: 2px solid #e2e8f0;
	border-radius: 10px;
	font-size: 1rem;
	font-family: 'Inter', sans-serif;
	transition: all 0.3s;
	background: white;
	color: var(--dark);
}

	.apply-form-container input:focus,
	.apply-form-container select:focus,
	.apply-form-container textarea:focus {
		outline: none;
		border-color: var(--primary);
		box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.1);
	}

.apply-form-container select {
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 1.25rem;
	padding-right: 3rem;
}

.apply-form-container textarea {
	min-height: 120px;
	resize: vertical;
}

.checkbox-group, .radio-group {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.checkbox-item, .radio-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	cursor: pointer;
	padding: 0.5rem;
	border-radius: 8px;
	transition: background 0.2s;
	font-weight: 400;
}

	.checkbox-item:hover, .radio-item:hover {
		background: var(--light);
	}

.apply-form-container input[type="checkbox"],
.apply-form-container input[type="radio"] {
	width: 20px;
	height: 20px;
	accent-color: var(--primary);
	cursor: pointer;
	padding: 0;
	border: none;
	box-shadow: none;
}

.help-text {
	font-size: 0.875rem;
	color: #718096;
	margin-top: 0.375rem;
}

/* File uploads */
.file-uploads-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
}

.file-upload {
	position: relative;
}

.file-upload-input {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
	z-index: 2;
}

.file-upload-label {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	border: 2px dashed #cbd5e0;
	border-radius: 12px;
	background: var(--light);
	transition: all 0.3s;
	cursor: pointer;
	text-align: center;
}

.file-upload:hover .file-upload-label {
	border-color: var(--primary);
	background: rgba(30, 58, 95, 0.05);
}

.file-upload-icon {
	font-size: 2.5rem;
	margin-bottom: 0.75rem;
}

.file-upload-text {
	font-weight: 500;
	color: var(--dark);
	margin-bottom: 0.25rem;
	font-size: 0.9rem;
}

.file-upload-hint {
	font-size: 0.8rem;
	color: #718096;
}

.file-selected {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.75rem;
	padding: 0.75rem 1rem;
	background: rgba(45, 90, 39, 0.1);
	border-radius: 8px;
	color: var(--nz-green);
	font-size: 0.9rem;
}

	.file-selected.hidden {
		display: none;
	}

.file-remove {
	margin-left: auto;
	background: none;
	border: none;
	color: var(--accent);
	cursor: pointer;
	font-size: 1.2rem;
	padding: 0.25rem;
	line-height: 1;
}

/* Submit button */
.btn-submit {
	background: var(--nz-gradient);
	color: white;
	padding: 1rem 3rem;
	border: none;
	border-radius: 30px;
	font-size: 1.1rem;
	font-weight: 600;
	font-family: 'Inter', sans-serif;
	cursor: pointer;
	transition: all 0.3s;
	display: block;
	margin: 2rem auto 0;
	width: 100%;
	max-width: 400px;
}

	.btn-submit:hover {
		transform: translateY(-3px);
		box-shadow: 0 15px 40px rgba(30, 58, 95, 0.3);
	}

.privacy-note {
	text-align: center;
	margin-top: 1.5rem;
	font-size: 0.875rem;
	color: #718096;
}

	.privacy-note a {
		color: var(--primary);
		text-decoration: none;
	}

		.privacy-note a:hover {
			text-decoration: underline;
		}

/* Success message */
.success-message {
	display: none;
	text-align: center;
	padding: 3rem;
}

	.success-message.active {
		display: block;
	}

.success-icon {
	font-size: 4rem;
	margin-bottom: 1rem;
}

.success-message h2 {
	font-family: 'Playfair Display', serif;
	font-size: 2rem;
	color: var(--primary);
	margin-bottom: 1rem;
}

.success-message p {
	color: var(--text);
	margin-bottom: 2rem;
}

.btn-home {
	background: var(--secondary);
	color: var(--primary);
	padding: 1rem 2.5rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	display: inline-block;
	transition: all 0.3s;
}

	.btn-home:hover {
		transform: translateY(-3px);
		box-shadow: 0 10px 30px rgba(212, 175, 55, 0.4);
		color: var(--primary);
	}

/* Apply responsive */
@media (max-width: 768px) {
	.apply-form-container {
		padding: 2rem 1.5rem;
	}

	.form-row {
		grid-template-columns: 1fr;
	}

	.file-uploads-grid {
		grid-template-columns: 1fr;
	}

	.progress-bar {
		flex-wrap: wrap;
		gap: 1rem;
	}

		.progress-bar::before {
			display: none;
		}
}


/* =============================================================
   BLOG PAGE
   ============================================================= */

.blog-section {
	padding: 4rem 5%;
	max-width: 1300px;
	margin: 0 auto;
}

.blog-categories {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 3rem;
}

.category-btn {
	padding: 0.6rem 1.5rem;
	background: white;
	border: 2px solid #e2e8f0;
	border-radius: 30px;
	cursor: pointer;
	font-weight: 500;
	font-size: 0.9rem;
	font-family: 'Inter', sans-serif;
	transition: all 0.3s;
	text-decoration: none;
	color: var(--dark);
}

	.category-btn:hover,
	.category-btn.active {
		background: var(--nz-gradient);
		color: white;
		border-color: transparent;
	}

/* Featured post */
.featured-post {
	background: white;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 10px 40px rgba(0,0,0,0.1);
	margin-bottom: 3rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.featured-image {
	background: var(--nz-gradient);
	min-height: 350px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 4rem;
}

.featured-content {
	padding: 3rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.featured-tag {
	display: inline-block;
	background: rgba(45, 90, 39, 0.1);
	color: var(--nz-green);
	padding: 0.4rem 1rem;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 600;
	margin-bottom: 1rem;
	width: fit-content;
}

.featured-content h2 {
	font-family: 'Playfair Display', serif;
	font-size: 1.8rem;
	color: var(--primary);
	margin-bottom: 1rem;
}

.featured-content > p {
	margin-bottom: 1.5rem;
	color: var(--text);
	line-height: 1.75;
}

.featured-meta {
	display: flex;
	gap: 1.5rem;
	font-size: 0.9rem;
	color: #718096;
	margin-bottom: 1.5rem;
	flex-wrap: wrap;
}

.btn-read {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: var(--nz-gradient);
	color: white;
	padding: 0.9rem 2rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	width: fit-content;
	transition: all 0.3s;
}

	.btn-read:hover {
		transform: translateY(-3px);
		box-shadow: 0 10px 30px rgba(30, 58, 95, 0.3);
		color: white;
	}

/* Blog grid */
.blog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
	gap: 2rem;
}

.blog-card {
	background: white;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0,0,0,0.08);
	transition: all 0.3s;
	text-decoration: none;
	color: inherit;
	display: block;
}

	.blog-card:hover {
		transform: translateY(-8px);
		box-shadow: 0 15px 40px rgba(0,0,0,0.12);
	}

.blog-image {
	height: 200px;
	background: var(--nz-gradient);
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 3rem;
}

.blog-content {
	padding: 1.5rem;
}

.blog-tag {
	display: inline-block;
	background: var(--light);
	color: var(--nz-green);
	padding: 0.3rem 0.8rem;
	border-radius: 15px;
	font-size: 0.8rem;
	font-weight: 500;
	margin-bottom: 0.75rem;
}

.blog-card h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.15rem;
	margin-bottom: 0.75rem;
	color: var(--primary);
	line-height: 1.4;
}

.blog-card p {
	font-size: 0.92rem;
	color: var(--text);
	margin-bottom: 1rem;
	line-height: 1.7;
}

.blog-meta {
	display: flex;
	gap: 1rem;
	font-size: 0.82rem;
	color: #718096;
}

/* Newsletter */
.blog-newsletter {
	background: var(--nz-gradient);
	padding: 4rem;
	border-radius: 16px;
	text-align: center;
	color: white;
	margin-top: 4rem;
}

	.blog-newsletter h2 {
		font-family: 'Playfair Display', serif;
		color: white;
		font-size: 2rem;
		margin-bottom: 1rem;
	}

	.blog-newsletter p {
		color: rgba(255,255,255,0.9);
		margin-bottom: 2rem;
		max-width: 500px;
		margin-left: auto;
		margin-right: auto;
	}

.newsletter-form {
	display: flex;
	gap: 1rem;
	max-width: 500px;
	margin: 0 auto;
}

.newsletter-input {
	flex: 1;
	padding: 1rem 1.5rem;
	border: none;
	border-radius: 30px;
	font-size: 1rem;
	font-family: 'Inter', sans-serif;
}

	.newsletter-input:focus {
		outline: none;
	}

.newsletter-btn {
	background: var(--secondary);
	color: var(--primary);
	padding: 1rem 2rem;
	border: none;
	border-radius: 30px;
	font-weight: 600;
	font-family: 'Inter', sans-serif;
	cursor: pointer;
	transition: all 0.3s;
	white-space: nowrap;
}

	.newsletter-btn:hover {
		transform: translateY(-2px);
		box-shadow: 0 8px 20px rgba(212, 175, 55, 0.4);
	}

/* Blog responsive */
@media (max-width: 768px) {
	.featured-post {
		grid-template-columns: 1fr;
	}

	.featured-image {
		min-height: 200px;
	}

	.featured-content {
		padding: 2rem 1.5rem;
	}

	.blog-grid {
		grid-template-columns: 1fr;
	}

	.newsletter-form {
		flex-direction: column;
	}

	.blog-newsletter {
		padding: 2.5rem 1.5rem;
	}
}


/* =============================================================
   APPLY PAGE
   ============================================================= */

.apply-form-section {
	padding: 4rem 5%;
	max-width: 1020px;
	margin: 0 auto;
}

.apply-form-container {
	background: white;
	padding: 3rem;
	border-radius: 20px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.1);
}

.form-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

	.form-header h2 {
		font-family: 'Playfair Display', serif;
		font-size: 2rem;
		color: var(--primary);
		margin-bottom: 0.5rem;
	}

	.form-header p {
		color: var(--text);
	}

/* Progress bar */
.apply-progress-bar {
	display: flex;
	justify-content: space-between;
	margin-bottom: 3rem;
	position: relative;
}

	.apply-progress-bar::before {
		content: '';
		position: absolute;
		top: 22px;
		left: 10%;
		right: 10%;
		height: 4px;
		background: #e2e8f0;
		z-index: 0;
	}

.progress-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	z-index: 1;
}

.step-circle {
	width: 44px;
	height: 44px;
	background: var(--nz-gradient);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 1rem;
	margin-bottom: 0.5rem;
}

.step-label {
	font-size: 0.82rem;
	color: var(--text);
	font-weight: 500;
	font-family: 'Inter', sans-serif;
}

/* Section titles */
.apply-section-title {
	font-family: 'Playfair Display', serif;
	font-size: 1.2rem;
	color: var(--primary);
	margin: 2.5rem 0 1.5rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var(--secondary);
}

.apply-doc-title {
	font-family: 'Inter', sans-serif;
	font-size: 1rem;
	color: var(--primary);
	margin: 2rem 0 1rem;
	font-weight: 600;
}

/* Form layout */
.apply-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
}

.apply-form-group {
	margin-bottom: 1.5rem;
}

	.apply-form-group label,
	.apply-form-section label {
		display: block;
		margin-bottom: 0.5rem;
		font-weight: 500;
		color: var(--dark);
		font-family: 'Inter', sans-serif;
	}

.apply-form-section .required {
	color: var(--accent);
}

.apply-form-section input[type="text"],
.apply-form-section input[type="email"],
.apply-form-section input[type="tel"],
.apply-form-section input[type="date"],
.apply-form-section input[type="number"],
.apply-form-section select,
.apply-form-section textarea {
	width: 100%;
	padding: 0.875rem 1rem;
	border: 2px solid #e2e8f0;
	border-radius: 10px;
	font-size: 1rem;
	font-family: 'Inter', sans-serif;
	transition: all 0.3s;
	background: white;
	color: var(--dark);
}

	.apply-form-section input:focus,
	.apply-form-section select:focus,
	.apply-form-section textarea:focus {
		outline: none;
		border-color: var(--primary);
		box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.1);
	}

.apply-form-section select {
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 1.25rem;
	padding-right: 3rem;
}

.apply-form-section textarea {
	min-height: 120px;
	resize: vertical;
}

.apply-form-section .checkbox-group,
.apply-form-section .radio-group {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

.apply-form-section .checkbox-item,
.apply-form-section .radio-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	cursor: pointer;
	padding: 0.45rem 0.6rem;
	border-radius: 8px;
	transition: background 0.2s;
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
}

	.apply-form-section .checkbox-item:hover,
	.apply-form-section .radio-item:hover {
		background: var(--light);
	}

.apply-form-section input[type="checkbox"],
.apply-form-section input[type="radio"] {
	width: 18px;
	height: 18px;
	accent-color: var(--primary);
	cursor: pointer;
	flex-shrink: 0;
}

.help-text {
	font-size: 0.875rem;
	color: #718096;
	margin-top: 0.35rem;
	font-family: 'Inter', sans-serif;
}

/* File uploads */
.file-uploads-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
}

.file-upload {
	position: relative;
}

.file-upload-input {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
	z-index: 2;
}

.file-upload-label {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 1.8rem 1rem;
	border: 2px dashed #cbd5e0;
	border-radius: 12px;
	background: var(--light);
	transition: all 0.3s;
	cursor: pointer;
	text-align: center;
	min-height: 120px;
}

.file-upload:hover .file-upload-label {
	border-color: var(--primary);
	background: rgba(30, 58, 95, 0.05);
}

.file-upload-icon {
	font-size: 2rem;
	margin-bottom: 0.5rem;
}

.file-upload-text {
	font-weight: 500;
	color: var(--dark);
	margin-bottom: 0.2rem;
	font-size: 0.9rem;
	font-family: 'Inter', sans-serif;
}

.file-upload-hint {
	font-size: 0.78rem;
	color: #718096;
	font-family: 'Inter', sans-serif;
}

.file-selected {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.6rem;
	padding: 0.6rem 1rem;
	background: rgba(45, 90, 39, 0.1);
	border-radius: 8px;
	color: var(--nz-green);
	font-size: 0.88rem;
	font-family: 'Inter', sans-serif;
}

	.file-selected.hidden {
		display: none;
	}

.file-name {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.file-remove {
	margin-left: auto;
	background: none;
	border: none;
	color: var(--accent);
	cursor: pointer;
	font-size: 1.1rem;
	padding: 0.2rem 0.4rem;
	line-height: 1;
	flex-shrink: 0;
}

/* Checklist info box */
.apply-checklist-box {
	background: var(--light);
	padding: 1.4rem 1.6rem;
	border-radius: 12px;
	margin-top: 2rem;
	font-family: 'Inter', sans-serif;
	font-size: 0.9rem;
}

	.apply-checklist-box p {
		color: var(--text);
		margin-bottom: 0.4rem;
		line-height: 1.7;
	}

/* Submit button */
.btn-apply-submit {
	background: var(--nz-gradient);
	color: white;
	padding: 1rem 3rem;
	border: none;
	border-radius: 30px;
	font-size: 1.05rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.3s;
	display: block;
	margin: 2rem auto 0;
	width: 100%;
	max-width: 400px;
	font-family: 'Inter', sans-serif;
}

	.btn-apply-submit:hover {
		transform: translateY(-3px);
		box-shadow: 0 15px 40px rgba(30, 58, 95, 0.3);
	}

.privacy-note {
	text-align: center;
	margin-top: 1.4rem;
	font-size: 0.875rem;
	color: #718096;
	font-family: 'Inter', sans-serif;
}

	.privacy-note a {
		color: var(--primary);
		text-decoration: none;
	}

/* Success message */
.apply-success {
	display: none;
	text-align: center;
	padding: 3rem 1rem;
}

	.apply-success.active {
		display: block;
	}

	.apply-success .success-icon {
		font-size: 4rem;
		margin-bottom: 1rem;
	}

	.apply-success h2 {
		font-family: 'Playfair Display', serif;
		font-size: 2rem;
		color: var(--primary);
		margin-bottom: 1rem;
	}

	.apply-success p {
		color: var(--text);
		margin-bottom: 2rem;
		line-height: 1.75;
	}

.btn-home {
	background: var(--secondary);
	color: var(--primary);
	padding: 1rem 2.5rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	display: inline-block;
	transition: all 0.3s;
	font-family: 'Inter', sans-serif;
}

	.btn-home:hover {
		transform: translateY(-3px);
		box-shadow: 0 10px 30px rgba(212, 175, 55, 0.4);
		color: var(--primary);
	}

/* Responsive */
@media (max-width: 768px) {
	.apply-form-container {
		padding: 1.8rem 1.2rem;
	}

	.apply-form-row {
		grid-template-columns: 1fr;
	}

	.file-uploads-grid {
		grid-template-columns: 1fr;
	}

	.apply-progress-bar {
		flex-wrap: wrap;
		gap: 1rem;
		justify-content: center;
	}

		.apply-progress-bar::before {
			display: none;
		}
}


/* =============================================================
   BLOG PAGE
   ============================================================= */

.blog-section {
	padding: 4rem 5%;
	max-width: 1240px;
	margin: 0 auto;
}

/* Category buttons */
.blog-categories {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 3rem;
}

.category-btn {
	padding: 0.6rem 1.5rem;
	background: white;
	border: 2px solid #e2e8f0;
	border-radius: 30px;
	cursor: pointer;
	font-weight: 500;
	font-size: 0.9rem;
	font-family: 'Inter', sans-serif;
	transition: all 0.3s;
	text-decoration: none;
	color: var(--dark);
}

	.category-btn:hover,
	.category-btn.active {
		background: var(--nz-gradient);
		color: white;
		border-color: transparent;
	}

/* Featured post */
.featured-post {
	background: white;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 10px 40px rgba(0,0,0,0.1);
	margin-bottom: 3rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.featured-image {
	background: var(--nz-gradient);
	min-height: 350px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 4rem;
}

.featured-content {
	padding: 3rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.featured-tag {
	display: inline-block;
	background: rgba(45, 90, 39, 0.1);
	color: var(--nz-green);
	padding: 0.4rem 1rem;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 600;
	margin-bottom: 1rem;
	width: fit-content;
	font-family: 'Inter', sans-serif;
}

.featured-content h2 {
	font-family: 'Playfair Display', serif;
	font-size: 1.75rem;
	color: var(--primary);
	margin-bottom: 1rem;
	line-height: 1.25;
}

.featured-content > p {
	color: var(--text);
	line-height: 1.75;
	margin-bottom: 1.5rem;
}

.featured-meta {
	display: flex;
	gap: 1.5rem;
	font-size: 0.88rem;
	color: #718096;
	margin-bottom: 1.5rem;
	font-family: 'Inter', sans-serif;
}

.btn-read {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: var(--nz-gradient);
	color: white;
	padding: 0.85rem 2rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	font-size: 0.92rem;
	width: fit-content;
	transition: all 0.3s;
	font-family: 'Inter', sans-serif;
}

	.btn-read:hover {
		transform: translateY(-3px);
		box-shadow: 0 10px 30px rgba(30, 58, 95, 0.3);
		color: white;
	}

/* Blog grid */
.blog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
	gap: 2rem;
}

.blog-card {
	background: white;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0,0,0,0.08);
	transition: all 0.35s;
	text-decoration: none;
	color: inherit;
	display: block;
}

	.blog-card:hover {
		transform: translateY(-8px);
		box-shadow: 0 15px 40px rgba(0,0,0,0.12);
	}

.blog-image {
	height: 180px;
	background: var(--nz-gradient);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.8rem;
}

.blog-content {
	padding: 1.5rem;
}

.blog-tag {
	display: inline-block;
	background: var(--light);
	color: var(--nz-green);
	padding: 0.28rem 0.75rem;
	border-radius: 15px;
	font-size: 0.78rem;
	font-weight: 600;
	margin-bottom: 0.75rem;
	font-family: 'Inter', sans-serif;
}

.blog-card h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.1rem;
	color: var(--primary);
	margin-bottom: 0.65rem;
	line-height: 1.35;
}

.blog-card p {
	font-size: 0.9rem;
	color: var(--text);
	line-height: 1.7;
	margin-bottom: 1rem;
	font-family: 'Inter', sans-serif;
}

.blog-meta {
	display: flex;
	gap: 1rem;
	font-size: 0.82rem;
	color: #718096;
	font-family: 'Inter', sans-serif;
}

/* Newsletter */
.blog-newsletter {
	background: var(--nz-gradient);
	padding: 4rem;
	border-radius: 16px;
	text-align: center;
	color: white;
	margin-top: 4rem;
}

	.blog-newsletter h2 {
		font-family: 'Playfair Display', serif;
		color: white;
		font-size: 2rem;
		margin-bottom: 1rem;
	}

	.blog-newsletter > p {
		color: rgba(255,255,255,0.9);
		margin-bottom: 2rem;
		max-width: 500px;
		margin-left: auto;
		margin-right: auto;
		line-height: 1.7;
		font-family: 'Inter', sans-serif;
	}

.newsletter-form {
	display: flex;
	gap: 1rem;
	max-width: 500px;
	margin: 0 auto;
}

.newsletter-input {
	flex: 1;
	padding: 1rem 1.5rem;
	border: none;
	border-radius: 30px;
	font-size: 1rem;
	font-family: 'Inter', sans-serif;
}

	.newsletter-input:focus {
		outline: none;
	}

.newsletter-btn {
	background: var(--secondary);
	color: var(--primary);
	padding: 1rem 2rem;
	border: none;
	border-radius: 30px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.3s;
	font-family: 'Inter', sans-serif;
	white-space: nowrap;
}

	.newsletter-btn:hover {
		transform: translateY(-2px);
		box-shadow: 0 8px 20px rgba(212, 175, 55, 0.4);
	}

/* Responsive */
@media (max-width: 768px) {
	.featured-post {
		grid-template-columns: 1fr;
	}

	.featured-image {
		min-height: 180px;
	}

	.featured-content {
		padding: 2rem 1.4rem;
	}

		.featured-content h2 {
			font-size: 1.4rem;
		}

	.blog-grid {
		grid-template-columns: 1fr;
	}

	.newsletter-form {
		flex-direction: column;
	}

	.blog-newsletter {
		padding: 2.5rem 1.5rem;
	}
}


/* =============================================================
   BLOG ARTICLE PAGE
   ============================================================= */

/* Article header (hero banner) */
.article-header {
	padding: 4rem 5%;
	background: var(--nz-gradient);
	text-align: center;
	color: white;
}

/* Breadcrumb */
.article-breadcrumb {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
	font-size: 0.9rem;
	font-family: 'Inter', sans-serif;
	flex-wrap: wrap;
}

	.article-breadcrumb a {
		color: rgba(255,255,255,0.8);
		text-decoration: none;
		transition: color 0.2s;
	}

		.article-breadcrumb a:hover {
			color: white;
		}

	.article-breadcrumb span {
		color: rgba(255,255,255,0.5);
	}

.article-header h1 {
	font-family: 'Playfair Display', serif;
	font-size: clamp(1.8rem, 3.5vw, 2.5rem);
	color: white;
	max-width: 820px;
	margin: 0 auto 1.5rem;
	line-height: 1.25;
	font-weight: 600;
}

.article-meta {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
	font-size: 0.92rem;
	color: rgba(255,255,255,0.9);
	font-family: 'Inter', sans-serif;
	flex-wrap: wrap;
}

/* Article body container */
.article-container {
	max-width: 840px;
	margin: 0 auto;
	padding: 3rem 5%;
}

.article-content {
	background: white;
	padding: 3rem;
	border-radius: 16px;
	box-shadow: 0 4px 24px rgba(0,0,0,0.08);
	line-height: 1.8;
}

	/* Article typography */
	.article-content h2 {
		font-family: 'Playfair Display', serif;
		font-size: 1.55rem;
		color: var(--primary);
		margin: 2.5rem 0 1rem;
		padding-bottom: 0.5rem;
		border-bottom: 2px solid var(--secondary);
		scroll-margin-top: 100px;
	}

	.article-content h3 {
		font-family: 'Playfair Display', serif;
		font-size: 1.2rem;
		color: var(--dark);
		margin: 1.8rem 0 0.8rem;
		font-weight: 600;
	}

	.article-content p {
		color: var(--text);
		font-size: 1.02rem;
		line-height: 1.82;
		margin-bottom: 1.1rem;
		font-family: 'Inter', sans-serif;
	}

	.article-content ul,
	.article-content ol {
		margin: 1rem 0 1.2rem 1.8rem;
	}

	.article-content li {
		color: var(--text);
		font-size: 1rem;
		line-height: 1.75;
		margin-bottom: 0.6rem;
		font-family: 'Inter', sans-serif;
	}

	.article-content strong {
		color: var(--primary);
	}

	.article-content a {
		color: var(--nz-green);
		text-decoration: none;
		font-weight: 500;
	}

		.article-content a:hover {
			text-decoration: underline;
		}

/* Table of contents */
.article-toc {
	background: var(--light);
	padding: 2rem;
	border-radius: 12px;
	margin-bottom: 2.2rem;
	border: 1px solid #e2e8f0;
}

	.article-toc h3 {
		font-family: 'Playfair Display', serif;
		color: var(--primary);
		font-size: 1.1rem;
		margin-bottom: 1rem;
		font-weight: 600;
	}

	.article-toc ul {
		list-style: none;
		padding: 0;
		margin: 0;
		columns: 2;
		column-gap: 2rem;
	}

	.article-toc li {
		margin-bottom: 0.5rem;
	}

	.article-toc a {
		color: var(--text);
		text-decoration: none;
		font-size: 0.92rem;
		font-family: 'Inter', sans-serif;
		transition: color 0.2s;
	}

		.article-toc a:hover {
			color: var(--primary);
		}

/* Inline tables */
.article-table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.5rem 0;
	font-family: 'Inter', sans-serif;
	font-size: 0.95rem;
}

	.article-table th {
		background: var(--primary);
		color: white;
		padding: 0.85rem 1rem;
		text-align: left;
		font-weight: 600;
	}

	.article-table td {
		padding: 0.85rem 1rem;
		border-bottom: 1px solid #e2e8f0;
		color: var(--text);
	}

	.article-table tr:nth-child(even) td {
		background: var(--light);
	}

	.article-table tr:hover td {
		background: rgba(30, 58, 95, 0.04);
	}

/* Info box (green) */
.info-box {
	background: rgba(45, 90, 39, 0.07);
	border-left: 4px solid var(--nz-green);
	padding: 1.4rem 1.6rem;
	margin: 2rem 0;
	border-radius: 0 8px 8px 0;
}

	.info-box h4 {
		font-family: 'Playfair Display', serif;
		color: var(--nz-green);
		margin-bottom: 0.6rem;
		font-size: 1.05rem;
	}

	.info-box p {
		margin: 0;
		color: var(--text);
		font-family: 'Inter', sans-serif;
	}

/* Warning box (red) */
.article-warning-box {
	background: rgba(255, 107, 107, 0.07);
	border-left: 4px solid var(--accent);
	padding: 1.4rem 1.6rem;
	margin: 2rem 0;
	border-radius: 0 8px 8px 0;
}

	.article-warning-box h4 {
		font-family: 'Playfair Display', serif;
		color: var(--accent);
		margin-bottom: 0.6rem;
		font-size: 1.05rem;
	}

	.article-warning-box p {
		margin: 0;
		color: var(--text);
		font-family: 'Inter', sans-serif;
	}

/* In-article CTA */
.article-cta-box {
	background: var(--nz-gradient);
	padding: 2.5rem;
	border-radius: 16px;
	text-align: center;
	color: white;
	margin: 3rem 0;
}

	.article-cta-box h3 {
		font-family: 'Playfair Display', serif;
		color: white;
		font-size: 1.5rem;
		margin-bottom: 0.75rem;
	}

	.article-cta-box p {
		color: rgba(255,255,255,0.9);
		margin-bottom: 1.5rem;
		font-family: 'Inter', sans-serif;
	}

.btn-article-cta {
	display: inline-block;
	background: var(--secondary);
	color: var(--primary);
	padding: 0.9rem 2.5rem;
	border-radius: 30px;
	text-decoration: none;
	font-weight: 600;
	font-family: 'Inter', sans-serif;
	transition: all 0.3s;
}

	.btn-article-cta:hover {
		transform: translateY(-3px);
		box-shadow: 0 10px 30px rgba(0,0,0,0.2);
		color: var(--primary);
	}

/* Author box */
.author-box {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	background: var(--light);
	padding: 1.5rem;
	border-radius: 12px;
	margin-top: 3rem;
	border: 1px solid #e2e8f0;
}

.author-avatar {
	width: 72px;
	height: 72px;
	background: var(--nz-gradient);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.8rem;
	flex-shrink: 0;
}

.author-info h4 {
	font-family: 'Playfair Display', serif;
	color: var(--primary);
	font-size: 1rem;
	margin-bottom: 0.4rem;
}

.author-info p {
	font-size: 0.9rem;
	color: var(--text);
	margin: 0;
	font-family: 'Inter', sans-serif;
	line-height: 1.6;
}

/* Related articles */
.related-articles {
	max-width: 840px;
	margin: 0 auto;
	padding: 0 5% 4rem;
}

	.related-articles > h3 {
		font-family: 'Playfair Display', serif;
		color: var(--primary);
		font-size: 1.3rem;
		margin-bottom: 1.5rem;
	}

.related-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.4rem;
}

.related-card {
	background: white;
	padding: 1.5rem;
	border-radius: 12px;
	box-shadow: 0 4px 16px rgba(0,0,0,0.07);
	text-decoration: none;
	color: inherit;
	transition: all 0.3s;
	border: 1px solid #e2e8f0;
	display: block;
}

	.related-card:hover {
		transform: translateY(-5px);
		box-shadow: 0 12px 32px rgba(0,0,0,0.12);
		border-color: var(--primary);
	}

	.related-card h4 {
		font-family: 'Playfair Display', serif;
		font-size: 1rem;
		color: var(--primary);
		margin-bottom: 0.5rem;
		line-height: 1.35;
	}

	.related-card p {
		font-size: 0.88rem;
		color: var(--text);
		margin: 0;
		font-family: 'Inter', sans-serif;
		line-height: 1.6;
	}

/* Responsive */
@media (max-width: 768px) {
	.article-content {
		padding: 1.8rem 1.2rem;
	}

	.article-meta {
		gap: 0.75rem;
		font-size: 0.82rem;
	}

	.article-toc ul {
		columns: 1;
	}

	.author-box {
		flex-direction: column;
		text-align: center;
	}

	.related-grid {
		grid-template-columns: 1fr;
	}
}


/* =============================================================
   ARTICLE DOWNLOAD BOX
   ============================================================= */
.article-download-box {
	display: flex;
	align-items: center;
	gap: 1.2rem;
	background: var(--light);
	border: 2px solid var(--secondary);
	border-radius: 12px;
	padding: 1.4rem 1.6rem;
	margin: 2rem 0;
}

.article-download-icon {
	font-size: 2.2rem;
	flex-shrink: 0;
}

.article-download-text {
	flex: 1;
}

	.article-download-text strong {
		display: block;
		font-family: 'Playfair Display', serif;
		font-size: 1rem;
		color: var(--primary);
		margin-bottom: 0.2rem;
	}

	.article-download-text p {
		font-size: 0.88rem;
		color: var(--text);
		margin: 0;
		font-family: 'Inter', sans-serif;
	}

.btn-download-pdf {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: var(--secondary);
	color: var(--primary);
	padding: 0.7rem 1.4rem;
	border-radius: 25px;
	text-decoration: none;
	font-weight: 700;
	font-size: 0.9rem;
	font-family: 'Inter', sans-serif;
	white-space: nowrap;
	flex-shrink: 0;
	transition: all 0.3s;
}

	.btn-download-pdf:hover {
		transform: translateY(-2px);
		box-shadow: 0 8px 20px rgba(212, 175, 55, 0.4);
		color: var(--primary);
	}

@media (max-width: 600px) {
	.article-download-box {
		flex-direction: column;
		text-align: center;
	}

	.btn-download-pdf {
		width: 100%;
		justify-content: center;
	}
}
