/* =========================================================================
   Vastukalakriti Interiors — Theme Styles
   Luxury furniture: warm neutrals, brass accent, generous whitespace.
   ========================================================================= */

:root {
	--ak-bg:      #faf7f2;
	--ak-bg-alt:  #f1ebe1;
	--ak-card:    #ffffff;
	--ak-ink:     #2a201a;
	--ak-ink-2:   #6b5a4e;
	--ak-muted:   #9b8a7c;
	--ak-line:    #e7ddcf;
	--ak-accent:  #b08d57;
	--ak-accent-d:#8c6e3f;
	--ak-dark:    #221a14;

	--ak-font-serif:  'Cormorant Garamond', 'Playfair Display', Georgia, serif;
	--ak-font-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

	--ak-radius:   2px;
	--ak-radius-l: 4px;
	--ak-shadow:   0 4px 30px rgba(34,26,20,.08);
	--ak-shadow-l: 0 10px 50px rgba(34,26,20,.12);

	--ak-container: 1320px;
	--ak-gutter:    clamp(16px, 3vw, 40px);
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--ak-bg);
	color: var(--ak-ink);
	font-family: var(--ak-font-sans);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--ak-accent); }
button { font: inherit; cursor: pointer; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	color: var(--ak-ink);
	letter-spacing: .005em;
	margin: 0 0 .5em;
	line-height: 1.15;
}

p { margin: 0 0 1em; }

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

.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px); -webkit-clip-path: inset(50%); clip-path: inset(50%);
	height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; word-wrap: normal !important;
}
.skip-link {
	position: absolute; top: -100px; left: 8px; background: var(--ak-ink); color: #fff; padding: 8px 12px;
	z-index: 9999;
}
.skip-link:focus { top: 8px; }

/* ---------- Layout helpers ---------- */
.container {
	width: 100%;
	max-width: var(--ak-container);
	margin: 0 auto;
	padding-left: var(--ak-gutter);
	padding-right: var(--ak-gutter);
}
.container.narrow { max-width: 820px; }
.text-center { text-align: center; }
.display { font-size: clamp(28px, 4.2vw, 56px); line-height: 1.08; letter-spacing: -.005em; font-weight: 500; }

.eyebrow {
	font-family: var(--ak-font-sans);
	font-size: 12px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--ak-accent);
	margin: 0 0 14px;
	font-weight: 500;
}
.eyebrow-light { color: rgba(255,255,255,.85); }

.section { padding: clamp(56px, 8vw, 110px) 0; }
.section-alt { background: var(--ak-bg-alt); }

.section-head { max-width: 760px; margin: 0 auto 48px; }
.section-title { margin: 0 0 14px; }
.section-sub { color: var(--ak-ink-2); margin: 0; font-size: 16px; }
.section-meta { color: var(--ak-muted); font-size: 13px; margin-top: 24px; }
.section-cta { margin-top: 18px; }

/* ---------- Buttons ---------- */
.btn {
	display: inline-block;
	padding: 14px 28px;
	border: 1px solid var(--ak-ink);
	background: var(--ak-ink);
	color: #fff;
	font-family: var(--ak-font-sans);
	font-size: 13px;
	letter-spacing: .22em;
	text-transform: uppercase;
	transition: all .25s ease;
	border-radius: var(--ak-radius);
	cursor: pointer;
}
.btn:hover { background: var(--ak-accent); border-color: var(--ak-accent); color: #fff; }
.btn-primary { background: var(--ak-accent); border-color: var(--ak-accent); color: #fff; }
.btn-primary:hover { background: var(--ak-accent-d); border-color: var(--ak-accent-d); }
.btn-outline { background: transparent; color: var(--ak-ink); border-color: var(--ak-ink); }
.btn-outline:hover { background: var(--ak-ink); color: #fff; }
.btn-lg { padding: 18px 36px; font-size: 13px; }
.btn-sm { padding: 10px 18px; font-size: 11px; }
.btn-link { display: inline; padding: 0; border: 0; background: transparent; color: var(--ak-accent); letter-spacing: .2em; }
.btn-link:hover { color: var(--ak-accent-d); background: transparent; }

.link-arrow {
	display: inline-block;
	color: var(--ak-accent);
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 500;
	margin-top: 12px;
	transition: transform .25s ease;
}
.card:hover .link-arrow,
.ess-card:hover .link-arrow { transform: translateX(4px); }

/* ---------- Top bar ---------- */
.topbar {
	background: var(--ak-dark);
	color: rgba(255,255,255,.85);
	font-size: 12px;
	letter-spacing: .12em;
}
.topbar-inner {
	display: flex;
	gap: 14px;
	align-items: center;
	justify-content: center;
	padding: 9px 0;
	flex-wrap: wrap;
}
.topbar-item { color: rgba(255,255,255,.85); text-transform: uppercase; }
.topbar-item:hover { color: #fff; }
.topbar-sep { color: rgba(255,255,255,.35); }

/* ---------- Header ---------- */
.site-header {
	background: var(--ak-bg);
	border-bottom: 1px solid var(--ak-line);
	position: sticky; top: 0; z-index: 50;
}
.header-inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 24px;
	align-items: center;
	padding: 12px;
}
.site-branding .site-title {
	font-family: var(--ak-font-serif);
	font-size: 30px;
	font-weight: 600;
	letter-spacing: .04em;
	color: var(--ak-ink);
}
.site-branding .site-description {
	font-size: 11px;
	letter-spacing: .25em;
	color: var(--ak-muted);
	text-transform: uppercase;
	margin: 0;
}
.custom-logo { max-height: 56px; width: auto; }

.main-navigation { display: flex; justify-content: center; }
.primary-menu {
	list-style: none;
	display: flex;
	gap: 36px;
	margin: 0; padding: 0;
}
.primary-menu a {
	font-size: 13px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--ak-ink);
	font-weight: 500;
	position: relative;
}
.primary-menu a::after {
	content: '';
	position: absolute; left: 0; right: 0; bottom: -8px;
	height: 1px; background: var(--ak-accent); transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
.primary-menu a:hover::after { transform: scaleX(1); }

.header-tools {
	display: flex;
	gap: 18px;
	align-items: center;
	justify-self: end;
}
.header-icon {
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--ak-ink);
	background: transparent; border: 0;
	padding: 6px;
	position: relative;
}
.header-icon:hover { color: var(--ak-accent); }
.cart-count {
	position: absolute; top: -4px; right: -4px;
	background: var(--ak-accent); color: #fff;
	font-size: 10px; line-height: 1;
	min-width: 18px; height: 18px;
	padding: 0 4px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 999px;
	font-weight: 600;
}

.menu-toggle {
	display: none;
	width: 38px; height: 38px;
	background: transparent;
	border: 0;
	flex-direction: column;
	justify-content: center;
	gap: 4px;
	padding: 0;
}
.menu-toggle .bar {
	display: block;
	width: 22px;
	height: 1.5px;
	background: var(--ak-ink);
	transition: transform .25s ease;
}

.header-search-panel {
	border-top: 1px solid var(--ak-line);
	background: var(--ak-bg);
	padding: 18px 0;
}
.search-form {
	display: flex;
	gap: 8px;
	max-width: 600px;
	margin: 0 auto;
}
.search-form .search-field {
	flex: 1;
	padding: 12px 16px;
	border: 1px solid var(--ak-line);
	background: #fff;
	font: inherit;
	border-radius: var(--ak-radius);
}
.search-form .search-field:focus { outline: 0; border-color: var(--ak-accent); }
.search-form .search-submit {
	padding: 12px 22px;
	background: var(--ak-ink);
	color: #fff;
	border: 0;
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
}

/* ---------- Hero ---------- */
.hero {
	min-height: clamp(420px, 75vh, 760px);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	color: #fff;
	position: relative;
	overflow: hidden;
	background-image:
		linear-gradient(rgba(34,26,20,.35), rgba(34,26,20,.55)),
		var(--hero-bg-desktop, none);
}
@media (max-width: 767px) {
	.hero {
		background-image:
			linear-gradient(rgba(34,26,20,.35), rgba(34,26,20,.55)),
			var(--hero-bg-mobile, var(--hero-bg-desktop, none));
	}
}
.hero--has-video { background-image: none; background-color: #1a130d; }
@media (max-width: 767px) {
	.hero--has-video.hero--video-desktop-only {
		background-image:
			linear-gradient(rgba(34,26,20,.35), rgba(34,26,20,.55)),
			var(--hero-bg-mobile, var(--hero-bg-desktop, none));
	}
	.hero--has-video.hero--video-desktop-only .hero-media { display: none; }
}
.hero-media {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
	pointer-events: none;
}
.hero-video {
	position: absolute;
	top: 50%; left: 50%;
	width: 100%; height: 100%;
	min-width: 100%; min-height: 100%;
	object-fit: cover;
	transform: translate(-50%, -50%);
}
.hero-video-embed {
	position: absolute;
	inset: 0;
}
.hero-video-embed iframe {
	position: absolute;
	top: 50%; left: 50%;
	width: 100vw;
	height: 56.25vw;
	min-width: 177.78vh;
	min-height: 100vh;
	transform: translate(-50%, -50%);
	border: 0;
	pointer-events: none;
}
.hero-media-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(rgba(34,26,20,.35), rgba(34,26,20,.55));
}
.hero-inner {
	text-align: center;
	max-width: 900px;
	padding-top: 60px;
	padding-bottom: 60px;
	position: relative;
	z-index: 1;
}
.hero--has-video .hero-scroll { z-index: 1; }
.hero-title {
	color: #fff;
	font-weight: 400;
	margin-bottom: 32px;
	font-size: clamp(34px, 6vw, 76px);
	letter-spacing: -.01em;
}
.hero-scroll { display: none !important; }
.hero-scroll span {
	display: block; width: 2px; height: 8px;
	background: #fff; margin: 8px auto 0;
	animation: ak-scroll 1.8s ease infinite;
}
@keyframes ak-scroll {
	0%   { transform: translateY(0);  opacity: 1; }
	100% { transform: translateY(12px); opacity: 0; }
}

/* ---------- Cards row of 3 ---------- */
.cards-3 {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
}
.card-collection {
	background: var(--ak-card);
	border-radius: var(--ak-radius-l);
	overflow: hidden;
	display: flex; flex-direction: column;
	box-shadow: var(--ak-shadow);
	color: var(--ak-ink);
	transition: transform .35s ease, box-shadow .35s ease;
}
.card-collection:hover { transform: translateY(-4px); box-shadow: var(--ak-shadow-l); color: var(--ak-ink); }
.card-collection .card-media {
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.card-collection .card-media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.card-collection .card-body { padding: 28px; }
.card-collection .card-title { font-size: 26px; margin: 0 0 8px; }
.card-collection .card-text { color: var(--ak-ink-2); margin: 0; }

/* Minimal variant: image with text underneath, no card background/shadow */
.section-collections--minimal .cards-3 { gap: 36px; }
.section-collections--minimal .card-collection {
	background: transparent;
	box-shadow: none;
	border-radius: 0;
}
.section-collections--minimal .card-collection:hover {
	transform: none;
	box-shadow: none;
}
.section-collections--minimal .card-collection .card-media {
	border-radius: 4px;
}
.section-collections--minimal .card-collection .card-media img {
	border-radius: 4px;
}
.section-collections--minimal .card-collection .card-body {
	padding: 18px 0 0;
	text-align: left;
}
.section-collections--minimal .card-collection .card-title {
	font-size: 22px;
	font-weight: 500;
	margin: 0 0 6px;
}
.section-collections--minimal .card-collection .card-text {
	font-size: 15px;
	line-height: 1.5;
}
.section-collections--minimal .section-head {
	max-width: none;
	width: 100%;
}
.section-collections--minimal .section-head .section-title {
	margin-bottom: 14px;
	font-size: clamp(22px, 2.4vw, 34px);
	line-height: 1.2;
	letter-spacing: -.01em;
}
@media (min-width: 768px) {
	.section-collections--minimal .section-head .section-title {
		white-space: nowrap;
	}
}
.section-collections--minimal .section-head .section-sub { font-size: 14px; }

.section-collections--full .section-collections__grid {
	width: 100%;
	padding-left: var(--ak-gutter);
	padding-right: var(--ak-gutter);
}
.section-collections--full .cards-3 {
	width: 100%;
	max-width: none;
}

/* ---------- Full-width banner (Vastu Full) ---------- */
.banner {
	position: relative;
	overflow: hidden;
}
.banner-full {
	width: 100%;
	display: flex;
	justify-content: center;
	color: #fff;
}
.banner-full-frame {
	position: relative;
	display: block;
	width: fit-content;
	max-width: 100%;
	isolation: isolate;
}
.banner-full-img {
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	vertical-align: top;
}
.banner-full-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		to top,
		rgba(34, 26, 20, .78) 0%,
		rgba(34, 26, 20, .35) 40%,
		rgba(34, 26, 20, .1) 100%
	);
	pointer-events: none;
}
.banner-full-content {
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 2;
	width: 100%;
	max-width: 720px;
	padding: clamp(28px, 4vw, 48px) clamp(24px, 4vw, 48px);
	pointer-events: auto;
}
.banner-full-title {
	color: #fff !important;
	font-weight: 400;
	margin: 0 0 14px;
	font-size: clamp(24px, 3.2vw, 48px);
	line-height: 1.12;
	letter-spacing: -.01em;
}
.banner-full-sub {
	color: rgba(255, 255, 255, .95);
	font-family: var(--ak-font-sans);
	font-size: clamp(14px, 1.4vw, 17px);
	line-height: 1.65;
	margin: 0 0 24px;
	max-width: 560px;
}
.btn-banner {
	display: inline-block;
	background: #fff;
	color: var(--ak-ink) !important;
	border: 0;
	padding: 15px 30px;
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 500;
	border-radius: 0;
	transition: background .25s ease, color .25s ease;
}
.btn-banner:hover {
	background: var(--ak-accent);
	color: #fff !important;
}

/* ---------- Category scroller ---------- */
.cat-scroller {
	position: relative;
	margin: 0 -20px;
}
.cat-track {
	display: flex;
	gap: 24px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	padding: 8px 20px 24px;
	scrollbar-width: none;
}
.cat-track::-webkit-scrollbar { display: none; }
.cat-card {
	flex: 0 0 240px;
	scroll-snap-align: start;
	text-align: center;
}
.cat-img {
	aspect-ratio: 1 / 1;
	background-size: cover;
	background-position: center;
	border-radius: 999px;
	background-color: var(--ak-bg-alt);
	transition: transform .35s ease;
}
.cat-card:hover .cat-img { transform: scale(1.04); }
.cat-label {
	display: block;
	margin-top: 16px;
	font-family: var(--ak-font-serif);
	font-size: 20px;
	color: var(--ak-ink);
}
.scroller-btn {
	position: absolute;
	top: 50%; transform: translateY(-50%);
	width: 44px; height: 44px;
	border-radius: 50%;
	background: #fff;
	border: 1px solid var(--ak-line);
	color: var(--ak-ink);
	font-size: 22px;
	line-height: 1;
	display: flex; align-items: center; justify-content: center;
	box-shadow: var(--ak-shadow);
	z-index: 2;
}
.scroller-btn:hover { background: var(--ak-ink); color: #fff; border-color: var(--ak-ink); }
.scroller-prev { left: 0; }
.scroller-next { right: 0; }

/* ---------- Products grid ---------- */
.products-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 32px 24px;
}
.product-card {
	display: flex; flex-direction: column;
	color: var(--ak-ink);
	transition: transform .3s ease;
}
.product-card:hover { color: var(--ak-ink); transform: translateY(-2px); }
.product-media {
	aspect-ratio: 4 / 5;
	background-size: cover;
	background-position: center;
	background-color: var(--ak-bg-alt);
	position: relative;
	margin-bottom: 18px;
	overflow: hidden;
}
.product-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.product-card:hover .product-media img { transform: scale(1.04); }
.product-badge {
	position: absolute; top: 14px; left: 14px;
	background: var(--ak-ink); color: #fff;
	font-size: 10px; letter-spacing: .2em; text-transform: uppercase;
	padding: 5px 10px;
}
.product-title {
	font-size: 18px;
	font-weight: 500;
	margin: 0 0 6px;
	line-height: 1.3;
}
.product-price { color: var(--ak-ink-2); font-size: 15px; }

/* ---------- Essentials ---------- */
.essentials-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 24px;
}
.ess-card {
	background: var(--ak-card);
	border: 1px solid var(--ak-line);
	display: flex; flex-direction: column;
	color: var(--ak-ink);
	transition: transform .3s ease, box-shadow .3s ease;
}
.ess-card:hover { transform: translateY(-3px); box-shadow: var(--ak-shadow); color: var(--ak-ink); }
.ess-img {
	aspect-ratio: 1 / 1;
	background-size: cover;
	background-position: center;
	background-color: var(--ak-bg-alt);
}
.ess-body { padding: 20px; }
.ess-title { font-size: 20px; margin: 0 0 4px; }
.ess-count { color: var(--ak-muted); font-size: 12px; letter-spacing: .15em; text-transform: uppercase; margin: 0 0 10px; }

/* ---------- Why Choose Us ---------- */
.section-why-choose {
	background: var(--ak-card);
}
.why-choose-head {
	max-width: 820px;
	margin: 0 auto 56px;
}
.why-choose-head .section-title {
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 600;
	margin-bottom: 18px;
}
.why-choose-intro {
	color: var(--ak-ink-2);
	font-size: 16px;
	line-height: 1.7;
	margin: 0 auto;
	max-width: 720px;
}
.section-why-choose--full .why-choose-layout {
	width: 100%;
	padding-left: var(--ak-gutter);
	padding-right: var(--ak-gutter);
}
.why-choose-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 360px) minmax(0, 1fr);
	gap: clamp(24px, 3vw, 48px);
	align-items: start;
}
.why-choose-col {
	display: flex;
	flex-direction: column;
	gap: 36px;
	padding-top: 12px;
}
.why-choose-point {
	position: relative;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--ak-line);
}
.why-choose-col .why-choose-point:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}
.why-choose-point--right {
	text-align: right;
}
.why-choose-point--left {
	text-align: left;
}
.why-choose-num {
	display: block;
	font-family: var(--ak-font-serif);
	font-size: clamp(42px, 5vw, 64px);
	line-height: 1;
	font-weight: 500;
	color: rgba(42, 32, 26, .12);
	margin-bottom: 10px;
}
.why-choose-point-title {
	font-family: var(--ak-font-sans);
	font-size: clamp(16px, 1.6vw, 18px);
	font-weight: 600;
	line-height: 1.35;
	margin: 0 0 8px;
	color: var(--ak-ink);
}
.why-choose-point-desc {
	font-size: 14px;
	line-height: 1.65;
	color: var(--ak-ink-2);
	margin: 0;
}
.why-choose-center {
	display: flex;
	justify-content: center;
}
.why-choose-arch {
	width: 100%;
	max-width: 360px;
}
.why-choose-arch-media {
	border-radius: 999px 999px 0 0;
	overflow: hidden;
	background: var(--ak-bg-alt);
}
.why-choose-arch-media img {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 4;
	object-fit: cover;
}
.why-choose-quote {
	position: relative;
	z-index: 1;
	margin: -28px 16px 0;
	padding: 18px 20px;
	background: #b08d57;
	color: #fff;
	box-shadow: 0 8px 24px rgba(176, 141, 87, .28);
}
.why-choose-quote p {
	margin: 0;
	font-family: var(--ak-font-serif);
	font-size: clamp(15px, 1.5vw, 18px);
	font-style: italic;
	font-weight: 500;
	line-height: 1.45;
	text-align: center;
}

/* ---------- Testimonials ---------- */
.section-testimonials { background: var(--ak-dark); color: rgba(255,255,255,.92); }
.section-testimonials .eyebrow { color: var(--ak-accent); }
.section-testimonials .section-title { color: #fff; }
.testimonial-slider {
	position: relative;
	max-width: 900px;
	margin: 0 auto;
}
.t-viewport { overflow: hidden; }
.t-track {
	display: flex;
	transition: transform .6s cubic-bezier(.4,0,.2,1);
}
.t-slide {
	flex: 0 0 100%;
	padding: 0 16px;
	margin: 0;
	text-align: center;
}
.t-quote-mark {
	font-family: var(--ak-font-serif);
	font-size: 100px;
	line-height: .8;
	color: var(--ak-accent);
	margin-bottom: 12px;
}
.t-quote {
	font-family: var(--ak-font-serif);
	font-size: clamp(20px, 2.4vw, 28px);
	font-style: italic;
	line-height: 1.5;
	color: #fff;
	margin: 0 0 28px;
	max-width: 720px;
	margin-left: auto; margin-right: auto;
}
.t-meta { display: flex; flex-direction: column; gap: 4px; }
.t-name { font-weight: 500; letter-spacing: .15em; text-transform: uppercase; font-size: 13px; color: #fff; font-family: var(--ak-font-sans); }
.t-role { color: rgba(255,255,255,.6); font-size: 13px; }
.t-btn {
	position: absolute;
	top: 50%; transform: translateY(-50%);
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid rgba(255,255,255,.3);
	color: #fff;
	font-size: 22px;
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
}
.t-btn:hover { background: rgba(255,255,255,.1); border-color: #fff; }
.t-prev { left: -8px; }
.t-next { right: -8px; }
@media (max-width: 768px) {
	.t-prev { left: 0; }
	.t-next { right: 0; }
}

/* ---------- Features ---------- */
.features-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 28px;
}
.feature {
	text-align: center;
	padding: 24px;
}
.feature-icon {
	width: 52px; height: 52px;
	margin: 0 auto 18px;
	color: var(--ak-accent);
}
.feature-icon svg { width: 100%; height: 100%; }
.feature-title { font-size: 20px; margin: 0 0 8px; }
.feature-desc { color: var(--ak-ink-2); margin: 0; font-size: 14px; }

/* ---------- Footer ---------- */
.site-footer { background: var(--ak-dark); color: rgba(255,255,255,.78); padding: 80px 0 0; margin-top: 0; }
.site-footer a { color: rgba(255,255,255,.78); }
.site-footer a:hover { color: var(--ak-accent); }
.footer-grid {
	display: grid;
	grid-template-columns: 1.4fr repeat(4, 1fr);
	gap: 40px;
	padding-bottom: 60px;
}
.footer-title {
	font-family: var(--ak-font-sans);
	font-size: 12px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: #fff;
	margin: 0 0 22px;
	font-weight: 600;
}
.footer-title-spaced { margin-top: 36px; }
.footer-col-brand .footer-title { font-family: var(--ak-font-serif); font-size: 28px; letter-spacing: .03em; text-transform: none; }
.footer-menu {
	list-style: none;
	padding: 0; margin: 0;
	display: flex; flex-direction: column;
	gap: 12px;
	font-size: 14px;
}
.footer-newsletter {
	display: flex;
	gap: 0;
	margin-top: 8px;
	flex-wrap: wrap;
}
.footer-newsletter input {
	flex: 1;
	min-width: 0;
	padding: 12px 14px;
	background: transparent;
	border: 1px solid rgba(255,255,255,.25);
	color: #fff;
	font: inherit;
}
.footer-newsletter input::placeholder { color: rgba(255,255,255,.45); }
.footer-newsletter input:focus { outline: 0; border-color: var(--ak-accent); }
.footer-newsletter button {
	padding: 12px 20px;
	background: var(--ak-accent);
	border: 1px solid var(--ak-accent);
	color: #fff;
	font-size: 11px;
	letter-spacing: .2em;
	text-transform: uppercase;
}
.footer-newsletter button:hover { background: var(--ak-accent-d); border-color: var(--ak-accent-d); }
.footer-newsletter .nl-msg { width: 100%; margin: 10px 0 0; font-size: 13px; color: var(--ak-accent); }

.footer-contact {
	border-top: 1px solid rgba(255,255,255,.1);
	padding: 50px 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 40px;
}
.footer-contact h4 {
	font-family: var(--ak-font-sans);
	font-size: 12px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: #fff;
	margin: 0 0 18px;
	font-weight: 600;
}
.footer-contact ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14px; }
.social-menu { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; font-size: 14px; }
.footer-contact-blurb p { font-size: 14px; color: rgba(255,255,255,.7); margin-bottom: 20px; }
.footer-contact-blurb .btn-outline { color: #fff; border-color: rgba(255,255,255,.4); }
.footer-contact-blurb .btn-outline:hover { background: #fff; color: var(--ak-dark); border-color: #fff; }

.footer-base {
	background: #110d09;
	padding: 22px 0;
	font-size: 12px;
	color: rgba(255,255,255,.5);
}
.footer-base-inner {
	display: flex; justify-content: space-between; align-items: center;
	flex-wrap: wrap; gap: 14px;
}
.footer-legal {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 22px;
}

/* ---------- Blog / generic ---------- */
.page-header { text-align: center; padding: 60px 0 30px; }
.page-title { font-size: clamp(28px, 4vw, 44px); margin: 0; }
.posts-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 40px 28px;
	padding: 20px 0 60px;
}
.card-post { background: var(--ak-card); border: 1px solid var(--ak-line); }
.card-post .card-media img { width: 100%; height: auto; }
.card-post .card-body { padding: 24px; }
.card-post .card-title { font-size: 22px; margin: 0 0 6px; }
.card-post .card-meta { font-size: 12px; color: var(--ak-muted); letter-spacing: .15em; text-transform: uppercase; margin-bottom: 12px; }
.card-post .card-excerpt { color: var(--ak-ink-2); font-size: 14px; }
.pagination { text-align: center; padding: 20px 0 60px; }
.pagination .page-numbers { display: inline-block; padding: 8px 14px; margin: 0 4px; border: 1px solid var(--ak-line); color: var(--ak-ink); }
.pagination .current { background: var(--ak-ink); color: #fff; border-color: var(--ak-ink); }

.single-page, .single-post { padding: 40px 0 80px; }
.entry-title { font-size: clamp(28px, 4.5vw, 52px); margin: 16px 0 24px; }
.entry-meta { font-size: 12px; color: var(--ak-muted); letter-spacing: .2em; text-transform: uppercase; }
.entry-media { margin-bottom: 32px; }
.entry-content p { font-size: 17px; color: var(--ak-ink); }

/* ---------- WooCommerce light overrides ---------- */
.wc-main { padding: 40px 0 80px; }
.woocommerce ul.products li.product .price {
	color: var(--ak-ink-2);
	font-family: var(--ak-font-sans);
	font-size: 14px;
}
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--ak-font-serif);
	font-size: 20px !important;
	font-weight: 500 !important;
	padding-top: 12px !important;
}
.woocommerce a.button,
.woocommerce button.button.alt,
.woocommerce-page #respond input#submit,
.woocommerce #respond input#submit.alt,
.woocommerce-page .button {
	background: var(--ak-ink) !important;
	color: #fff !important;
	border-radius: var(--ak-radius) !important;
	padding: 12px 22px !important;
	letter-spacing: .2em;
	text-transform: uppercase;
	font-size: 12px;
}
.woocommerce a.button:hover,
.woocommerce button.button.alt:hover { background: var(--ak-accent) !important; }

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
	.products-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
	.essentials-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
	.features-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
	.footer-grid { grid-template-columns: 1fr 1fr 1fr; }
}
@media (max-width: 860px) {
	.header-inner { grid-template-columns: auto 1fr auto; }
	.menu-toggle { display: inline-flex; }
	/* Mobile nav handled by the premium block below — leave defaults */

	.cards-3 { grid-template-columns: 1fr; }
	.why-choose-layout {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.why-choose-center { order: -1; }
	.why-choose-col { gap: 28px; padding-top: 0; }
	.why-choose-point--right,
	.why-choose-point--left { text-align: left; }
	.banner-full-content { max-width: none; }

	.products-grid { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 28px 16px; }
	.essentials-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
	.features-grid { grid-template-columns: 1fr 1fr; }

	.footer-grid { grid-template-columns: 1fr 1fr; }
	.footer-contact { grid-template-columns: 1fr; gap: 28px; }
	.posts-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
	.products-grid { grid-template-columns: 1fr 1fr; }
	.features-grid { grid-template-columns: 1fr; }
	.essentials-grid { grid-template-columns: 1fr 1fr; }
	.footer-grid { grid-template-columns: 1fr; }
	.posts-grid { grid-template-columns: 1fr; }
	.topbar-sep { display: none; }
}

/* =========================================================================
   Inner pages: shop, collections, product, about, contact
   ========================================================================= */

/* ---------- Page banner (shared) ---------- */
.page-banner {
	background: var(--ak-bg-alt);
	padding: clamp(48px, 7vw, 100px) 0 clamp(40px, 6vw, 80px);
	text-align: center;
	border-bottom: 1px solid var(--ak-line);
}
.page-banner-title { margin: 0 0 14px; }
.page-banner-sub { color: var(--ak-ink-2); max-width: 640px; margin: 0 auto; font-size: 16px; }

/* ---------- Shop / Products page ---------- */
.shop-section { padding: clamp(40px, 6vw, 80px) 0; }
.shop-layout {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 48px;
	align-items: flex-start;
}
.shop-sidebar { position: sticky; top: 110px; }
.filters-toggle {
	display: none;
	align-items: center;
	gap: 8px;
	background: transparent;
	border: 1px solid var(--ak-ink);
	color: var(--ak-ink);
	padding: 10px 16px;
	font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
	width: 100%;
	justify-content: center;
}
.filter-group { padding: 22px 0; border-bottom: 1px solid var(--ak-line); }
.filter-group:first-child { padding-top: 0; }
.filter-title {
	font-family: var(--ak-font-sans);
	font-size: 12px;
	letter-spacing: .25em;
	text-transform: uppercase;
	margin: 0 0 16px;
	color: var(--ak-ink);
	font-weight: 600;
}
.filter-list, .filter-list-checks, .filter-swatches { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14px; }
.filter-list a { color: var(--ak-ink-2); transition: color .2s; }
.filter-list a:hover, .filter-list a.is-active { color: var(--ak-accent); }
.filter-list-checks label { display: flex; align-items: center; gap: 10px; cursor: pointer; color: var(--ak-ink-2); }
.filter-list-checks input[type="checkbox"] { accent-color: var(--ak-accent); }
.filter-swatches { flex-direction: row; flex-wrap: wrap; gap: 10px; }
.swatch {
	width: 30px; height: 30px;
	border-radius: 50%;
	border: 1px solid var(--ak-line);
	cursor: pointer;
	padding: 0;
	transition: transform .2s ease, box-shadow .2s ease;
}
.swatch:hover, .swatch.is-active {
	transform: scale(1.08);
	box-shadow: 0 0 0 2px var(--ak-bg), 0 0 0 3px var(--ak-accent);
}
.filter-reset { margin-top: 20px; width: 100%; }

.shop-toolbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--ak-line);
	margin-bottom: 28px;
	gap: 16px;
	flex-wrap: wrap;
}
.shop-count { margin: 0; color: var(--ak-muted); font-size: 13px; letter-spacing: .1em; }
.shop-sort label { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--ak-muted); margin-right: 10px; }
.shop-sort select {
	padding: 8px 12px;
	border: 1px solid var(--ak-line);
	background: #fff;
	font: inherit;
	color: var(--ak-ink);
	font-size: 14px;
}
.products-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.product-wishlist {
	position: absolute; top: 12px; right: 12px;
	background: rgba(255,255,255,.9);
	border: 0;
	width: 36px; height: 36px;
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	color: var(--ak-ink);
	opacity: 0;
	transition: opacity .25s ease, color .2s ease;
	cursor: pointer;
}
.product-card:hover .product-wishlist { opacity: 1; }
.product-wishlist:hover { color: var(--ak-accent); }
.shop-pagination { padding: 40px 0 0; text-align: center; }
.shop-pagination .next { margin-left: 12px; }

/* ---------- Collections page ---------- */
.section-collection-list { padding-top: clamp(48px, 6vw, 90px); }
.collection-list { display: flex; flex-direction: column; gap: clamp(60px, 8vw, 120px); }
.collection-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: center;
}
.collection-row.is-reverse { direction: rtl; }
.collection-row.is-reverse > * { direction: ltr; }
.collection-row-media { position: relative; display: block; overflow: hidden; }
.collection-row-img {
	aspect-ratio: 4 / 3;
	background-size: cover;
	background-position: center;
	background-color: var(--ak-bg-alt);
	transition: transform .6s ease;
}
.collection-row-media:hover .collection-row-img { transform: scale(1.04); }
.collection-row-count {
	position: absolute;
	bottom: 18px; left: 18px;
	background: rgba(255,255,255,.95);
	color: var(--ak-ink);
	padding: 8px 14px;
	font-size: 11px;
	letter-spacing: .25em;
	text-transform: uppercase;
}
.collection-row-title { margin: 0 0 18px; }
.collection-row-desc { color: var(--ak-ink-2); margin: 0 0 26px; max-width: 520px; }

/* ---------- Single product page ---------- */
.product-main { padding: 30px 0 80px; }
.breadcrumbs { font-size: 12px; letter-spacing: .15em; text-transform: uppercase; color: var(--ak-muted); display: flex; flex-wrap: wrap; gap: 8px; padding: 20px 0; }
.breadcrumbs a { color: var(--ak-ink-2); }
.breadcrumbs a:hover { color: var(--ak-accent); }

.product-detail {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: clamp(32px, 5vw, 70px);
	align-items: flex-start;
	padding: 20px 0 60px;
}
.product-gallery-main {
	background: var(--ak-bg-alt);
	aspect-ratio: 4 / 5;
	overflow: hidden;
	display: flex; align-items: center; justify-content: center;
}
.product-gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.product-gallery-thumbs {
	list-style: none; padding: 0; margin: 16px 0 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
}
.pg-thumb {
	width: 100%;
	background: var(--ak-bg-alt);
	border: 1.5px solid transparent;
	padding: 0;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	cursor: pointer;
	transition: border-color .2s;
}
.pg-thumb.is-active { border-color: var(--ak-accent); }
.pg-thumb img { width: 100%; height: 100%; object-fit: cover; }

.product-summary .eyebrow { margin-top: 0; }
.product-summary .product-title { font-size: clamp(28px, 3.5vw, 42px); margin: 0 0 16px; }
.product-rating {
	display: flex; align-items: center; gap: 10px;
	margin-bottom: 22px;
}
.product-rating .stars { color: var(--ak-accent); letter-spacing: 2px; font-size: 16px; }
.rating-meta { font-size: 13px; color: var(--ak-ink-2); }
.rating-meta a { color: var(--ak-ink-2); text-decoration: underline; text-underline-offset: 3px; }

.product-price-row {
	display: flex; align-items: baseline; gap: 14px;
	padding: 18px 0;
	border-top: 1px solid var(--ak-line);
	border-bottom: 1px solid var(--ak-line);
	margin-bottom: 24px;
}
.product-price-now { font-family: var(--ak-font-serif); font-size: 32px; color: var(--ak-ink); }
.product-price-tax { font-size: 12px; color: var(--ak-muted); letter-spacing: .15em; text-transform: uppercase; }

.product-shortdesc { color: var(--ak-ink-2); margin-bottom: 28px; }

.product-options { display: flex; flex-direction: column; gap: 22px; margin-bottom: 28px; }
.opt-group { display: flex; flex-direction: column; gap: 10px; }
.opt-label { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--ak-ink); font-weight: 600; }
.opt-swatches { list-style: none; padding: 0; margin: 0; display: flex; gap: 10px; }
.opt-select {
	padding: 12px 14px;
	border: 1px solid var(--ak-line);
	background: #fff;
	font: inherit;
	max-width: 320px;
}
.qty-stepper {
	display: inline-flex; align-items: center;
	border: 1px solid var(--ak-line);
	width: max-content;
}
.qty-stepper button {
	width: 44px; height: 44px;
	background: transparent;
	border: 0;
	font-size: 18px;
	cursor: pointer;
	color: var(--ak-ink);
}
.qty-stepper button:hover { background: var(--ak-bg-alt); }
.qty-stepper input {
	width: 56px; height: 44px;
	text-align: center;
	border: 0; border-left: 1px solid var(--ak-line); border-right: 1px solid var(--ak-line);
	font: inherit;
	-moz-appearance: textfield;
}
.qty-stepper input::-webkit-outer-spin-button,
.qty-stepper input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.product-actions {
	display: flex; align-items: center; gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 28px;
}
.btn-icon-only {
	width: 52px; height: 52px;
	border: 1px solid var(--ak-ink);
	background: transparent;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--ak-ink);
	cursor: pointer;
	transition: background .25s, color .25s;
}
.btn-icon-only:hover { background: var(--ak-ink); color: #fff; }

.product-perks {
	list-style: none; padding: 22px 0 0; margin: 0;
	border-top: 1px solid var(--ak-line);
	display: flex; flex-direction: column; gap: 14px;
	font-size: 14px;
	color: var(--ak-ink-2);
}
.product-perks li { display: flex; align-items: center; gap: 12px; }
.product-perks svg { color: var(--ak-accent); flex-shrink: 0; }

/* Tabs */
.product-tabs { padding: 50px 0; border-top: 1px solid var(--ak-line); }
.tabs-nav {
	list-style: none; padding: 0; margin: 0 0 30px;
	display: flex; gap: 30px;
	border-bottom: 1px solid var(--ak-line);
	flex-wrap: wrap;
}
.tab {
	background: transparent; border: 0;
	padding: 14px 0;
	font-size: 13px; letter-spacing: .2em; text-transform: uppercase;
	color: var(--ak-ink-2);
	cursor: pointer;
	position: relative;
	font-weight: 500;
}
.tab.is-active { color: var(--ak-ink); }
.tab.is-active::after {
	content: ''; position: absolute; left: 0; right: 0; bottom: -1px;
	height: 2px; background: var(--ak-accent);
}
.tab-panel { display: none; max-width: 820px; }
.tab-panel.is-active { display: block; }
.tab-panel p { color: var(--ak-ink-2); }
.specs-list { display: grid; grid-template-columns: 200px 1fr; gap: 14px 28px; }
.specs-list dt { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--ak-muted); }
.specs-list dd { margin: 0; color: var(--ak-ink); }

.product-reviews { padding: 60px 0; border-top: 1px solid var(--ak-line); }
.product-reviews .section-head { margin-bottom: 30px; }
.reviews-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0,1fr));
	gap: 24px;
}
.review-card {
	background: var(--ak-bg-alt);
	padding: 26px;
	margin: 0;
}
.review-stars { color: var(--ak-accent); letter-spacing: 2px; margin-bottom: 12px; }
.review-card blockquote { font-family: var(--ak-font-serif); font-size: 20px; font-style: italic; margin: 0 0 16px; line-height: 1.45; color: var(--ak-ink); }
.review-card figcaption { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--ak-muted); }

.product-related { padding: 60px 0 0; border-top: 1px solid var(--ak-line); }

/* ---------- About page ---------- */
.about-intro-grid {
	display: grid;
	grid-template-columns: 1fr 1.05fr;
	gap: clamp(32px, 5vw, 70px);
	align-items: center;
}
.about-image {
	aspect-ratio: 4 / 5;
	background-size: cover;
	background-position: center;
	background-color: var(--ak-bg-alt);
}
.about-intro-body h2 { margin-bottom: 24px; }
.about-intro-body p { color: var(--ak-ink-2); margin-bottom: 18px; }

.about-stats { background: var(--ak-dark); color: #fff; padding: 60px 0; }
.stats-grid {
	list-style: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	text-align: center;
}
.stat-k {
	display: block;
	font-size: clamp(36px, 4vw, 56px);
	color: var(--ak-accent);
	margin-bottom: 8px;
	line-height: 1;
}
.stat-v {
	font-size: 12px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
}

.process-list {
	list-style: none; padding: 0; margin: 40px 0 0;
	counter-reset: step;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 30px;
}
.process-step {
	border-top: 2px solid var(--ak-accent);
	padding-top: 22px;
}
.process-n {
	font-family: var(--ak-font-serif);
	font-size: 36px;
	color: var(--ak-accent);
	display: block;
	margin-bottom: 12px;
	line-height: 1;
}
.process-t { font-size: 20px; margin: 0 0 8px; }
.process-d { color: var(--ak-ink-2); font-size: 14px; margin: 0; }

.about-quote { background: var(--ak-bg-alt); }
.quote-mark { color: var(--ak-accent); margin: 0 auto 16px; display: block; }
.about-quote-text { font-style: italic; color: var(--ak-ink); margin: 0 auto 18px; font-weight: 400; }
.about-quote-meta { font-size: 12px; letter-spacing: .25em; text-transform: uppercase; color: var(--ak-muted); }

.about-cta-grid {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 60px;
}
.about-cta-grid h2 { margin-bottom: 16px; }
.about-cta-grid p { color: var(--ak-ink-2); margin-bottom: 24px; }

/* ---------- Contact page ---------- */
.contact-grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: clamp(32px, 5vw, 70px);
	align-items: flex-start;
}
.contact-form-wrap header { margin-bottom: 26px; }
.contact-form-wrap header h2 { margin: 0 0 8px; }
.contact-form-wrap header p { color: var(--ak-ink-2); margin: 0; }

.form-flash {
	padding: 14px 16px;
	margin-bottom: 22px;
	border: 1px solid;
	font-size: 14px;
}
.form-flash-success { color: #2c5e2c; background: #ecf6ec; border-color: #cfe2cf; }
.form-flash-error   { color: #8a2222; background: #fbecec; border-color: #f2cdcd; }

.contact-form { display: flex; flex-direction: column; gap: 18px; }
.form-row { display: flex; flex-direction: column; gap: 6px; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-row-2 label { display: flex; flex-direction: column; gap: 6px; margin: 0; }
.form-row span,
.form-row-2 span {
	font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
	color: var(--ak-ink); font-weight: 600;
}
.contact-form input,
.contact-form textarea,
.contact-form select {
	padding: 14px;
	border: 1px solid var(--ak-line);
	background: #fff;
	font: inherit;
	color: var(--ak-ink);
	font-size: 15px;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus { outline: 0; border-color: var(--ak-accent); }
.contact-form textarea { resize: vertical; min-height: 140px; }
.form-check {
	display: flex; align-items: center; gap: 10px;
	font-size: 14px; color: var(--ak-ink-2);
	cursor: pointer;
}
.form-check input { accent-color: var(--ak-accent); }
.contact-form .btn { align-self: flex-start; margin-top: 6px; }

.contact-aside {
	background: var(--ak-bg-alt);
	padding: 32px;
	position: sticky; top: 110px;
}
.aside-title {
	font-family: var(--ak-font-sans);
	font-size: 12px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--ak-ink);
	margin: 0 0 20px;
	font-weight: 600;
}
.aside-title-spaced { margin-top: 30px; }
.contact-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 18px; }
.contact-list li { display: flex; flex-direction: column; gap: 4px; font-size: 14px; color: var(--ak-ink); }
.cl-label { font-size: 11px; letter-spacing: .25em; text-transform: uppercase; color: var(--ak-muted); }
.social-menu-inline { flex-wrap: wrap; }

.showrooms-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0,1fr));
	gap: 24px;
}
.showroom-card {
	background: var(--ak-card);
	border: 1px solid var(--ak-line);
	padding: 30px;
	display: flex; flex-direction: column; gap: 12px;
}
.showroom-city { font-size: 24px; margin: 0; }
.showroom-addr { margin: 0; color: var(--ak-ink-2); }
.showroom-meta { margin: 0; font-size: 14px; color: var(--ak-ink-2); }

/* ---------- Responsive overrides for new pages ---------- */
@media (max-width: 1100px) {
	.products-grid-3 { grid-template-columns: repeat(2, minmax(0,1fr)); }
	.reviews-grid { grid-template-columns: 1fr 1fr; }
	.process-list { grid-template-columns: repeat(2, 1fr); }
	.showrooms-grid { grid-template-columns: repeat(2, 1fr); }
	.stats-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
	.shop-layout { grid-template-columns: 1fr; }
	.shop-sidebar { position: static; }
	.filters-toggle { display: inline-flex; }
	.filters-panel { display: none; padding-top: 18px; }
	.shop-sidebar.is-open .filters-panel { display: block; }

	.collection-row { grid-template-columns: 1fr; gap: 26px; }
	.collection-row.is-reverse { direction: ltr; }

	.product-detail { grid-template-columns: 1fr; }
	.product-gallery-thumbs { grid-template-columns: repeat(4, 1fr); }
	.specs-list { grid-template-columns: 1fr; gap: 4px 0; }
	.specs-list dd { margin-bottom: 12px; }
	.reviews-grid { grid-template-columns: 1fr; }

	.about-intro-grid { grid-template-columns: 1fr; }
	.about-cta-grid { grid-template-columns: 1fr; gap: 32px; }
	.process-list { grid-template-columns: 1fr 1fr; }

	.contact-grid { grid-template-columns: 1fr; }
	.contact-aside { position: static; }
	.showrooms-grid { grid-template-columns: 1fr; }
	.form-row-2 { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
	.products-grid-3 { grid-template-columns: 1fr; }
	.process-list { grid-template-columns: 1fr; }
	.stats-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
}

/* =========================================================================
   B2B mode — Enquiry buttons (WhatsApp + Call), product card adjustments
   ========================================================================= */

.enquiry-buttons {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: 18px;
}
.enquiry-buttons.is-stacked { flex-direction: column; align-items: stretch; }
.enquiry-buttons.is-stacked .btn { width: 100%; justify-content: center; }

.btn-whatsapp,
.btn-call {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	letter-spacing: .18em;
}
.btn-whatsapp svg,
.btn-call svg { flex-shrink: 0; }

.btn-whatsapp {
	background: #25D366;
	border-color: #25D366;
	color: #fff !important;
}
.btn-whatsapp:hover {
	background: #1ebe5d;
	border-color: #1ebe5d;
	color: #fff !important;
}

.btn-call {
	background: transparent;
	color: var(--ak-ink) !important;
	border-color: var(--ak-ink);
}
.btn-call:hover {
	background: var(--ak-ink);
	color: #fff !important;
}

.btn-md { padding: 14px 26px; font-size: 12px; }

/* Header WA + Call icons (B2B replacement for cart) */
.header-wa:hover,
.header-call:hover { color: var(--ak-accent); }

/* Page banner enquiry buttons (centered) */
.page-banner .enquiry-buttons {
	justify-content: center;
	margin-top: 26px;
}

/* Product cards: remove price styling, add subtitle + "Enquire →" */
.product-price,
.product-price-row,
.product-price-now,
.product-price-tax { display: none !important; }

.product-sub {
	font-size: 13px;
	color: var(--ak-muted);
	letter-spacing: .08em;
	margin-top: 4px;
}
.product-enquire {
	display: inline-block;
	margin-top: 10px;
	font-size: 11px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--ak-accent);
	font-weight: 500;
	transition: transform .25s ease;
}
.product-card:hover .product-enquire { transform: translateX(4px); }

/* Product detail page — B2B enquiry block */
.product-code {
	font-size: 12px;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--ak-muted);
	margin: 0 0 18px;
}
.product-subtitle {
	font-family: var(--ak-font-serif);
	font-size: 20px;
	color: var(--ak-ink-2);
	font-style: italic;
	margin: -6px 0 18px;
}
.product-quickspecs {
	list-style: none;
	padding: 22px;
	margin: 22px 0 28px;
	background: var(--ak-bg-alt);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 24px;
	font-size: 14px;
	color: var(--ak-ink-2);
}
.product-quickspecs strong {
	display: block;
	font-size: 11px;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--ak-muted);
	font-weight: 600;
	margin-bottom: 2px;
}
@media (max-width: 600px) { .product-quickspecs { grid-template-columns: 1fr; } }

.product-enquiry-block {
	padding: 28px;
	background: var(--ak-bg-alt);
	border: 1px solid var(--ak-line);
	margin: 28px 0;
}
.enquiry-title {
	font-size: 22px;
	margin: 0 0 6px;
}
.enquiry-sub {
	color: var(--ak-ink-2);
	margin: 0;
	font-size: 14px;
}
.product-enquiry-block .enquiry-buttons { margin-top: 18px; }

/* Filter sidebar enquiry block */
.filter-enquiry { margin-top: 20px; }
.filter-desc {
	color: var(--ak-ink-2);
	font-size: 13px;
	margin: -4px 0 14px;
}

/* Filter pills + active state */
.filter-list a.is-active {
	color: var(--ak-accent);
	font-weight: 500;
}
.filter-count {
	color: var(--ak-muted);
	font-size: 12px;
	margin-left: 4px;
}
.shop-filter-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px;
	background: var(--ak-bg-alt);
	border: 1px solid var(--ak-line);
	font-size: 12px;
	letter-spacing: .15em;
	text-transform: uppercase;
}
.shop-filter-pill a {
	color: var(--ak-ink-2);
	font-size: 16px;
	line-height: 1;
}
.shop-filter-pill a:hover { color: var(--ak-accent); }

/* Empty CTA */
.empty-cta {
	padding: 22px;
	background: var(--ak-bg-alt);
	border: 1px dashed var(--ak-line);
	color: var(--ak-ink-2);
	margin-bottom: 28px;
	font-size: 14px;
}

/* Section bottom CTA strip */
.section-bottom-cta .enquiry-buttons {
	justify-content: center;
	margin-top: 26px;
}

/* Floating WhatsApp button on mobile (optional, hidden on desktop) */
@media (max-width: 768px) {
	.header-wa,
	.header-call { display: inline-flex; }
}

/* ---------- Our Collection (collage) ---------- */
.section-our-collection {
	background: var(--ak-bg);
}
.our-coll-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-auto-rows: 220px;
	gap: 16px;
}
.our-coll-intro {
	grid-column: 1 / span 1;
	grid-row: 1 / span 1;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	padding: 8px 8px 0 0;
}
.our-coll-eyebrow {
	font-family: var(--ak-font-serif);
	font-style: italic;
	font-weight: 500;
	font-size: clamp(24px, 2.4vw, 34px);
	line-height: 1.15;
	margin: 0 0 12px;
	color: var(--ak-ink);
}
.our-coll-sub {
	color: var(--ak-ink-2);
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
	max-width: 280px;
}
.our-coll-card {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 4px;
	background: var(--ak-bg-alt);
}
.our-coll-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .6s ease;
}
.our-coll-card:hover img {
	transform: scale(1.04);
}
.our-coll-card-label {
	position: absolute;
	left: 14px;
	bottom: 14px;
	background: rgba(34, 26, 20, .72);
	color: #fff;
	padding: 8px 14px;
	font-size: 13px;
	letter-spacing: .08em;
	border-radius: 2px;
	opacity: 0;
	transform: translateY(6px);
	transition: opacity .3s ease, transform .3s ease;
}
.our-coll-card:hover .our-coll-card-label {
	opacity: 1;
	transform: translateY(0);
}
.our-coll-card.pos-1 { grid-column: 1 / span 1; grid-row: 2 / span 1; }
.our-coll-card.pos-2 { grid-column: 2 / span 2; grid-row: 1 / span 2; }
.our-coll-card.pos-3 { grid-column: 4 / span 1; grid-row: 1 / span 1; }
.our-coll-card.pos-4 { grid-column: 4 / span 1; grid-row: 2 / span 1; }
.our-coll-card.pos-5 { grid-column: 1 / span 2; grid-row: 3 / span 1; }
.our-coll-card.pos-6 { grid-column: 3 / span 2; grid-row: 3 / span 1; }

@media (max-width: 900px) {
	.our-coll-grid {
		grid-template-columns: repeat(2, 1fr);
		grid-auto-rows: 200px;
	}
	.our-coll-intro {
		grid-column: 1 / -1;
		grid-row: auto;
		padding: 0 0 8px;
	}
	.our-coll-card.pos-1,
	.our-coll-card.pos-2,
	.our-coll-card.pos-3,
	.our-coll-card.pos-4,
	.our-coll-card.pos-5,
	.our-coll-card.pos-6 {
		grid-column: auto;
		grid-row: auto;
	}
	.our-coll-card.pos-2 { grid-column: 1 / span 2; }
	.our-coll-card.pos-5 { grid-column: 1 / span 2; }
}
@media (max-width: 520px) {
	.our-coll-grid { grid-template-columns: 1fr; grid-auto-rows: 240px; }
	.our-coll-card.pos-2,
	.our-coll-card.pos-5 { grid-column: auto; }
}

/* =========================================================
   Custom: Full-width "Uncover Your Style" / Our Collection
   Added per request — overrides .container width inside #our-collection.
   To revert: remove this block.
   ========================================================= */
#our-collection > .container {
	max-width: 100%;
	width: 100%;
	padding-left: clamp(20px, 3vw, 56px);
	padding-right: clamp(20px, 3vw, 56px);
}
#our-collection .our-coll-intro {
	padding-left: 0;
	padding-right: 0;
}
#our-collection .our-coll-grid {
	gap: 18px;
	grid-auto-rows: clamp(260px, 22vw, 360px);
}
@media (max-width: 900px) {
	#our-collection .our-coll-grid {
		grid-auto-rows: clamp(240px, 32vw, 300px);
	}
}
@media (max-width: 520px) {
	#our-collection .our-coll-grid {
		grid-auto-rows: 320px;
	}
}
/* Make the bottom-row cards (Tables + Coasters) taller */
#our-collection .our-coll-card.pos-5,
#our-collection .our-coll-card.pos-6 {
	min-height: clamp(380px, 30vw, 520px);
}
@media (max-width: 900px) {
	#our-collection .our-coll-card.pos-5,
	#our-collection .our-coll-card.pos-6 {
		min-height: clamp(300px, 42vw, 420px);
	}
}

/* =========================================================
   Custom: Premium testimonials refresh
   Adds gold ornaments, hairline dividers, refined arrows.
   To revert: remove this block.
   ========================================================= */
.section-testimonials {
	padding-top: clamp(80px, 9vw, 140px);
	padding-bottom: clamp(80px, 9vw, 140px);
	background:
		radial-gradient(circle at 50% 22%, rgba(193,154,91,.07) 0%, transparent 55%),
		var(--ak-dark);
}
.section-testimonials .section-head { padding-bottom: 8px; }
.section-testimonials .eyebrow {
	display: inline-block;
	position: relative;
	padding: 0 44px;
	letter-spacing: .32em;
}
.section-testimonials .eyebrow::before,
.section-testimonials .eyebrow::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 32px;
	height: 1px;
	background: var(--ak-accent);
	opacity: .6;
}
.section-testimonials .eyebrow::before { right: 100%; }
.section-testimonials .eyebrow::after  { left: 100%; }
.section-testimonials .section-title {
	font-weight: 400;
	font-style: normal;
	letter-spacing: .005em;
	margin-top: 22px;
	font-size: clamp(34px, 4.6vw, 64px);
}
.testimonial-slider {
	max-width: 980px;
	margin-top: 64px;
	padding: 56px 24px;
	position: relative;
}
.testimonial-slider::before,
.testimonial-slider::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: clamp(180px, 32vw, 280px);
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, rgba(193,154,91,.6) 50%, transparent 100%);
}
.testimonial-slider::before { top: 0; }
.testimonial-slider::after  { bottom: 0; }
.t-quote-mark {
	font-size: clamp(80px, 9vw, 132px);
	line-height: .7;
	opacity: .9;
	margin-bottom: 22px;
}
.t-quote {
	font-size: clamp(22px, 2.4vw, 30px);
	line-height: 1.6;
	margin-bottom: 44px;
	max-width: 820px;
	color: rgba(255,255,255,.95);
	font-weight: 300;
	letter-spacing: .005em;
}
.t-meta { align-items: center; gap: 10px; }
.t-name {
	font-size: 12px;
	letter-spacing: .34em;
	color: rgba(255,255,255,.95);
	position: relative;
	display: inline-block;
	padding-bottom: 12px;
}
.t-name::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: 28px;
	height: 1px;
	background: var(--ak-accent);
}
.t-role {
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: rgba(255,255,255,.55);
	margin-top: 4px;
}
.t-btn {
	width: 54px;
	height: 54px;
	border-color: rgba(193,154,91,.4);
	color: rgba(255,255,255,.85);
	transition: background .35s ease, color .35s ease, border-color .35s ease, transform .35s ease;
}
.t-btn:hover {
	background: var(--ak-accent);
	border-color: var(--ak-accent);
	color: var(--ak-dark);
	transform: translateY(-50%) scale(1.06);
}
.t-prev { left: -28px; }
.t-next { right: -28px; }
@media (max-width: 900px) {
	.t-prev { left: -4px; }
	.t-next { right: -4px; }
	.testimonial-slider { padding: 44px 56px; }
}

/* =========================================================
   Custom: Projects slider section
   Queries ak_project CPT. Renders a horizontal-scroll slider
   with hover border + "View Project" button.
   ========================================================= */
.section-projects {
	padding: clamp(80px, 9vw, 140px) 0;
	background: var(--ak-bg);
}
.section-projects .section-head { margin-bottom: 56px; }
.section-projects .section-intro {
	max-width: 600px;
	margin: 16px auto 0;
	color: var(--ak-ink-2);
	font-size: 16px;
}
.projects-slider { position: relative; }
.projects-viewport {
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding: 4px 0;
	margin: 0 -6px;
}
.projects-viewport::-webkit-scrollbar { display: none; }
.projects-track {
	display: flex;
	gap: 24px;
	padding: 0 6px;
}
.project-card {
	/* Column count is controlled from Theme Dashboard → Home: Our Work
	   via the --ak-work-cols custom property (defaults to 4). Track gap is 24px. */
	flex: 0 0 calc((100% - (var(--ak-work-cols, 4) - 1) * 24px) / var(--ak-work-cols, 4));
	min-width: 240px;
	scroll-snap-align: start;
	text-decoration: none;
	color: inherit;
	display: block;
}
@media (max-width: 1100px) {
	.project-card { flex: 0 0 calc(33.33% - 16px); }
}
@media (max-width: 800px) {
	.project-card { flex: 0 0 calc(50% - 12px); }
}
@media (max-width: 540px) {
	.project-card { flex: 0 0 80%; min-width: 0; }
}

/* Grid layout mode (no horizontal scroll, wrapping rows, no arrows) */
.projects-slider.is-grid .projects-viewport {
	overflow: visible;
	scroll-snap-type: none;
}
.projects-slider.is-grid .projects-track {
	flex-wrap: wrap;
	row-gap: 36px;
}
.projects-slider.is-grid .project-card {
	min-width: 0;
}
.projects-slider.is-grid .projects-btn { display: none; }
@media (min-width: 1101px) {
	/* In grid mode let the chosen column count fully drive widths */
	.projects-slider.is-grid .project-card {
		flex: 0 0 calc((100% - (var(--ak-work-cols, 4) - 1) * 24px) / var(--ak-work-cols, 4));
	}
}
.project-card__frame {
	position: relative;
	aspect-ratio: 3/4;
	background-color: var(--ak-dark);
	background-size: cover;
	background-position: center;
	overflow: hidden;
}
.project-card__frame::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 60%, rgba(0,0,0,.55) 100%);
	z-index: 1;
}
.project-card__border {
	position: absolute;
	inset: 18px;
	pointer-events: none;
	z-index: 2;
}
.project-card__border .pcb {
	position: absolute;
	background: rgba(255,255,255,.55);
	transition: transform .55s cubic-bezier(.22,.61,.36,1);
}
.project-card__border .pcb--top {
	top: 0; left: 0;
	height: 1px; width: 100%;
	transform: scaleX(0);
	transform-origin: left center;
}
.project-card__border .pcb--right {
	top: 0; right: 0;
	width: 1px; height: 100%;
	transform: scaleY(0);
	transform-origin: center bottom;
}
.project-card__border .pcb--bottom {
	bottom: 0; right: 0;
	height: 1px; width: 100%;
	transform: scaleX(0);
	transform-origin: right center;
}
.project-card__border .pcb--left {
	top: 0; left: 0;
	width: 1px; height: 100%;
	transform: scaleY(0);
	transform-origin: center top;
}
.project-card__status {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 3;
	background: rgba(193,154,91,.95);
	color: var(--ak-dark);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: .2em;
	text-transform: uppercase;
	padding: 6px 12px;
}
.project-card__body {
	position: absolute;
	top: 32px;
	left: 0;
	right: 0;
	text-align: center;
	z-index: 3;
	padding: 0 22px;
}
.project-card__title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: clamp(20px, 1.7vw, 28px);
	color: #f5ede0;
	margin: 0 0 8px;
	line-height: 1.2;
	text-shadow: 0 1px 14px rgba(0,0,0,.4);
}
.project-card__location {
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: rgba(245,237,224,.78);
	margin: 0;
}
.project-card__cta {
	position: absolute;
	left: 50%;
	bottom: 32px;
	transform: translateX(-50%) translateY(8px);
	background: #fff;
	color: var(--ak-dark);
	font-size: 11px;
	letter-spacing: .28em;
	font-weight: 600;
	text-transform: uppercase;
	padding: 13px 30px;
	opacity: 0;
	transition: opacity .4s ease, transform .4s ease;
	z-index: 3;
	white-space: nowrap;
}
.project-card:hover .pcb--top    { transform: scaleX(1); }
.project-card:hover .pcb--right  { transform: scaleY(1); }
.project-card:hover .pcb--bottom { transform: scaleX(1); }
.project-card:hover .pcb--left   { transform: scaleY(1); }
.project-card:hover .project-card__cta {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}
@media (hover: none) {
	.project-card__cta { opacity: 1; transform: translateX(-50%) translateY(0); }
}
/* Slider buttons */
.projects-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 54px;
	height: 54px;
	background: #fff;
	border: 1px solid rgba(0,0,0,.08);
	color: var(--ak-dark);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 6px 20px rgba(0,0,0,.08);
	transition: background .3s ease, color .3s ease, transform .3s ease, opacity .3s ease;
	z-index: 5;
}
.projects-prev { left: -24px; }
.projects-next { right: -24px; }
.projects-btn:hover {
	background: var(--ak-accent);
	color: #fff;
	transform: translateY(-50%) scale(1.06);
}
.projects-btn.is-disabled {
	opacity: .3;
	pointer-events: none;
}
@media (max-width: 900px) {
	.projects-prev { left: 4px; }
	.projects-next { right: 4px; }
}

/* Full-width Projects section + remove arrow buttons */
.section-projects > .container {
	max-width: 100%;
	width: 100%;
	padding-left: clamp(20px, 3vw, 56px);
	padding-right: clamp(20px, 3vw, 56px);
}
/* Show both navigation arrows on the slider */
.section-projects .projects-prev { display: flex; left: 16px; }
.section-projects .projects-next { display: flex; right: 16px; }
/* Hide the arrows on mobile (swipe to scroll instead) */
@media (max-width: 768px) {
	.section-projects .projects-prev,
	.section-projects .projects-next { display: none; }
}

/* =========================================================
   PROJECTS ARCHIVE PAGE
   Premium gallery: hero / stats / filter / grid / lightbox / CTA
   ========================================================= */
.projects-archive { color: var(--ak-ink); }

/* -------- Hero -------- */
.proj-hero {
	position: relative;
	min-height: clamp(320px, 48vh, 500px);
	background-color: #1a1411;
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	color: #fff;
	overflow: hidden;
}
.proj-hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.3) 40%, rgba(0,0,0,.7) 100%);
	z-index: 1;
}
.proj-hero__inner { position: relative; z-index: 2; padding: 56px 0; max-width: 900px; }
.proj-breadcrumb {
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
	margin: 0 0 28px;
	display: flex;
	gap: 10px;
	align-items: center;
}
.proj-breadcrumb a { color: inherit; text-decoration: none; transition: color .3s ease; }
.proj-breadcrumb a:hover { color: var(--ak-accent); }
.proj-hero__eyebrow {
	font-size: 13px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--ak-accent);
	margin: 0 0 22px;
	opacity: 0;
	transform: translateY(14px);
	animation: projFadeUp .9s .15s ease forwards;
}
.proj-hero__eyebrow span { display: inline-block; padding-bottom: 6px; border-bottom: 1px solid rgba(193,154,91,.55); }
.proj-hero__title {
	font-family: var(--ak-font-serif);
	font-weight: 400;
	font-size: clamp(40px, 6vw, 86px);
	line-height: 1.04;
	margin: 0 0 24px;
	letter-spacing: -.005em;
	color: #fff;
	text-shadow: 0 1px 14px rgba(0,0,0,.25);
	opacity: 0;
	transform: translateY(20px);
	animation: projFadeUp 1.1s .3s ease forwards;
}
.proj-hero__sub {
	font-size: clamp(15px, 1.4vw, 19px);
	line-height: 1.6;
	color: rgba(255,255,255,.85);
	max-width: 640px;
	margin: 0 0 40px;
	opacity: 0;
	transform: translateY(20px);
	animation: projFadeUp 1.1s .45s ease forwards;
}
.proj-hero__scroll {
	position: absolute;
	bottom: 32px;
	left: 50%;
	transform: translateX(-50%);
	width: 1px; height: 64px;
	display: block;
	background: transparent;
	overflow: hidden;
}
.proj-hero__scroll-line {
	display: block;
	width: 100%; height: 100%;
	background: linear-gradient(180deg, rgba(255,255,255,.1) 0%, var(--ak-accent) 100%);
	animation: projScrollLine 2.4s ease-in-out infinite;
}
@keyframes projFadeUp { to { opacity: 1; transform: translateY(0); } }
@keyframes projScrollLine {
	0%   { transform: scaleY(0); transform-origin: top; }
	50%  { transform: scaleY(1); transform-origin: top; }
	51%  { transform: scaleY(1); transform-origin: bottom; }
	100% { transform: scaleY(0); transform-origin: bottom; }
}

/* -------- Stats -------- */
.proj-stats {
	background: #fff;
	border-bottom: 1px solid rgba(0,0,0,.06);
}
.proj-stats__inner {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	padding: clamp(60px, 7vw, 110px) 0;
	gap: 32px;
	text-align: center;
}
@media (max-width: 640px) {
	.proj-stats__inner { grid-template-columns: 1fr; padding: 56px 0; }
}
.proj-stat__num {
	font-family: var(--ak-font-serif);
	font-size: clamp(48px, 6vw, 84px);
	line-height: 1;
	margin: 0 0 14px;
	color: var(--ak-ink);
	font-weight: 500;
	letter-spacing: -.01em;
}
.proj-stat__suffix { color: var(--ak-accent); margin-left: 2px; }
.proj-stat__label {
	font-size: 12px;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ak-ink-2);
	margin: 0;
}

/* -------- Toolbar (filter + search) -------- */
.proj-toolbar { padding: 56px 0 24px; background: var(--ak-bg); }
.proj-toolbar__inner {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	align-items: center;
	justify-content: space-between;
}
.proj-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.proj-chip {
	background: transparent;
	border: 1px solid rgba(0,0,0,.12);
	color: var(--ak-ink);
	padding: 10px 20px;
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 500;
	cursor: pointer;
	transition: all .3s ease;
	font-family: var(--ak-font-sans);
	border-radius: 999px;
}
.proj-chip:hover { border-color: var(--ak-accent); color: var(--ak-accent); }
.proj-chip.is-active { background: var(--ak-ink); color: #fff; border-color: var(--ak-ink); }
.proj-search {
	position: relative;
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 0 16px;
	background: #fff;
	border: 1px solid rgba(0,0,0,.1);
	border-radius: 999px;
	min-width: 260px;
	transition: border-color .3s ease;
}
.proj-search:focus-within { border-color: var(--ak-accent); }
.proj-search svg { color: var(--ak-ink-2); flex-shrink: 0; }
.proj-search__input {
	flex: 1;
	border: 0;
	background: transparent;
	padding: 12px 0;
	font-size: 14px;
	outline: none;
	color: var(--ak-ink);
	font-family: inherit;
}

/* -------- Grid -------- */
.proj-grid-wrap { padding: 32px 0 100px; background: var(--ak-bg); }
.proj-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
}
@media (max-width: 1100px) { .proj-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; } }
@media (max-width: 820px)  { .proj-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; } }
@media (max-width: 480px)  { .proj-grid { grid-template-columns: 1fr; } }

.proj-card {
	position: relative;
	opacity: 1;
	transform: translateY(0);
	transition: opacity .8s ease, transform .8s ease;
	transition-delay: var(--reveal-delay, 0ms);
}
/* JS adds .js-reveal-enabled on <body> after init, then animates cards in. */
.js-reveal-enabled .proj-card { opacity: 0; transform: translateY(22px); }
.js-reveal-enabled .proj-card.is-visible { opacity: 1; transform: translateY(0); }
.proj-card.is-filtered-out { display: none; }

/* Placeholder for cards without a featured image */
.proj-card__media--empty {
	background: linear-gradient(135deg, #ece2cf 0%, #d9c8a8 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	text-align: center;
}
.proj-card__media-fallback {
	font-family: var(--ak-font-serif);
	font-style: italic;
	font-weight: 500;
	font-size: clamp(18px, 1.4vw, 22px);
	color: rgba(42,32,26,.55);
	line-height: 1.3;
	letter-spacing: .01em;
}
.proj-card__link {
	display: block;
	text-decoration: none;
	color: inherit;
}
.proj-card__media {
	position: relative;
	aspect-ratio: 4/5;
	overflow: hidden;
	background: #f0e9dd;
	border-radius: 2px;
}
.proj-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 1.1s cubic-bezier(.2,.6,.2,1), filter .6s ease;
}
.proj-card__link:hover .proj-card__media img {
	transform: scale(1.08);
	filter: brightness(.78);
}
.proj-card__media::after {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.5) 100%);
	opacity: 0;
	transition: opacity .5s ease;
	pointer-events: none;
}
.proj-card__link:hover .proj-card__media::after { opacity: 1; }

.proj-card__zoom {
	position: absolute;
	top: 50%; left: 50%;
	width: 56px; height: 56px;
	transform: translate(-50%, -50%) scale(.6);
	background: rgba(255,255,255,.95);
	color: var(--ak-ink);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity .4s ease, transform .5s cubic-bezier(.2,.8,.2,1);
	pointer-events: none;
}
.proj-card__link:hover .proj-card__zoom {
	opacity: 1;
	transform: translate(-50%, -50%) scale(1);
}

.proj-card__info {
	padding: 20px 4px 0;
}
.proj-card__cat {
	font-size: 10px;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ak-accent);
	margin: 0 0 8px;
	font-weight: 600;
}
.proj-card__title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: 20px;
	line-height: 1.25;
	margin: 0 0 6px;
	color: var(--ak-ink);
	transition: color .3s ease;
}
.proj-card__link:hover .proj-card__title { color: var(--ak-accent); }
.proj-card__loc {
	font-size: 12px;
	color: var(--ak-ink-2);
	margin: 0;
	letter-spacing: .05em;
}
.proj-grid__empty {
	text-align: center;
	padding: 80px 20px;
	color: var(--ak-ink-2);
	font-size: 16px;
}

/* -------- CTA -------- */
.proj-cta {
	background: var(--ak-dark);
	color: #fff;
	padding: clamp(80px, 9vw, 130px) 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.proj-cta::before {
	content: "";
	position: absolute;
	top: -120px; left: 50%;
	width: 800px; height: 800px;
	transform: translateX(-50%);
	background: radial-gradient(circle, rgba(193,154,91,.18) 0%, transparent 60%);
	pointer-events: none;
}
.proj-cta__inner { position: relative; }
.proj-cta__title {
	font-family: var(--ak-font-serif);
	font-weight: 400;
	font-size: clamp(34px, 4vw, 56px);
	line-height: 1.1;
	margin: 0 0 18px;
}
.proj-cta__sub {
	font-size: 16px;
	color: rgba(255,255,255,.75);
	max-width: 580px;
	margin: 0 auto 36px;
	line-height: 1.6;
}
.proj-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	background: var(--ak-accent);
	color: var(--ak-dark);
	padding: 16px 36px;
	font-size: 12px;
	letter-spacing: .28em;
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	transition: transform .3s ease, background .3s ease, box-shadow .3s ease;
	box-shadow: 0 8px 24px rgba(193,154,91,.25);
}
.proj-cta__btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 30px rgba(193,154,91,.35);
}
.proj-cta__btn svg { transition: transform .3s ease; }
.proj-cta__btn:hover svg { transform: translateX(4px); }

/* -------- Reveal on scroll -------- */
[data-reveal] {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity .9s ease, transform .9s ease;
}
[data-reveal].is-visible { opacity: 1; transform: translateY(0); }

/* -------- Lightbox -------- */
.proj-lightbox {
	position: fixed; inset: 0;
	z-index: 9999;
	visibility: hidden;
	opacity: 0;
	transition: opacity .4s ease, visibility .4s ease;
}
.proj-lightbox.is-open {
	visibility: visible;
	opacity: 1;
}
.proj-lightbox__backdrop {
	position: absolute; inset: 0;
	background: rgba(8, 6, 5, .92);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.proj-lightbox__close,
.proj-lightbox__nav {
	position: absolute;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.15);
	color: #fff;
	width: 48px; height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all .3s ease;
	z-index: 3;
}
.proj-lightbox__close { top: 24px; right: 24px; }
.proj-lightbox__nav { top: 50%; transform: translateY(-50%); }
.proj-lightbox__prev { left: 24px; }
.proj-lightbox__next { right: 24px; }
.proj-lightbox__close:hover,
.proj-lightbox__nav:hover {
	background: var(--ak-accent);
	border-color: var(--ak-accent);
	color: var(--ak-dark);
}
.proj-lightbox__stage {
	position: relative;
	z-index: 2;
	display: flex;
	height: 100%;
	max-width: 1480px;
	margin: 0 auto;
	padding: 90px 96px 60px;
	gap: 48px;
	align-items: center;
}
.proj-lightbox__media {
	flex: 1 1 65%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	max-height: calc(100vh - 150px);
	overflow: hidden;
}
.proj-lightbox__thumbs {
	display: flex;
	gap: 8px;
	max-width: 100%;
	overflow-x: auto;
	padding: 4px 2px;
	scrollbar-width: thin;
}
.proj-lightbox__thumbs::-webkit-scrollbar { height: 4px; }
.proj-lightbox__thumbs::-webkit-scrollbar-thumb { background: rgba(255,255,255,.25); border-radius: 2px; }
.proj-lightbox__thumb {
	flex: 0 0 64px;
	width: 64px;
	height: 64px;
	border: 1px solid rgba(255,255,255,.18);
	background-size: cover;
	background-position: center;
	background-color: rgba(255,255,255,.04);
	cursor: pointer;
	padding: 0;
	opacity: .55;
	transition: opacity .25s ease, border-color .25s ease, transform .25s ease;
}
.proj-lightbox__thumb:hover { opacity: .85; }
.proj-lightbox__thumb.is-active {
	opacity: 1;
	border-color: var(--ak-accent);
	transform: scale(1.05);
}
.proj-lightbox__img {
	max-width: 100%;
	max-height: calc(100vh - 150px);
	object-fit: contain;
	display: block;
	opacity: 0;
	transform: translateX(20px) scale(.98);
	transition: opacity .5s ease, transform .5s ease;
}
.proj-lightbox__img.is-loaded {
	opacity: 1;
	transform: translateX(0) scale(1);
}
.proj-lightbox__panel {
	flex: 0 1 360px;
	color: #fff;
	max-height: calc(100vh - 150px);
	overflow-y: auto;
}
.proj-lightbox__cat {
	font-size: 10px;
	letter-spacing: .32em;
	text-transform: uppercase;
	color: var(--ak-accent);
	margin: 0 0 14px;
	font-weight: 600;
}
.proj-lightbox__cat:empty { display: none; }
.proj-lightbox__title {
	font-family: var(--ak-font-serif);
	font-weight: 400;
	font-size: clamp(26px, 2.4vw, 38px);
	line-height: 1.15;
	margin: 0 0 12px;
	color: #fff;
}
.proj-lightbox__loc {
	font-size: 13px;
	color: rgba(255,255,255,.85);
	margin: 0 0 22px;
	letter-spacing: .05em;
}
.proj-lightbox__loc:empty { display: none; }
.proj-lightbox__divider {
	width: 36px; height: 1px;
	background: var(--ak-accent);
	margin: 0 0 22px;
}
.proj-lightbox__desc {
	font-size: 15px;
	color: rgba(255,255,255,.92);
	line-height: 1.7;
	margin: 0 0 28px;
}
.proj-lightbox__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 11px;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ak-accent);
	text-decoration: none;
	padding-bottom: 6px;
	border-bottom: 1px solid rgba(193,154,91,.5);
	transition: color .3s ease, border-color .3s ease;
}
.proj-lightbox__cta:hover { color: #fff; border-color: #fff; }
.proj-lightbox__counter {
	position: absolute;
	bottom: 28px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 11px;
	letter-spacing: .25em;
	color: rgba(255,255,255,.55);
	margin: 0;
}
.proj-lightbox__counter span { color: #fff; }

@media (max-width: 900px) {
	.proj-lightbox__stage { flex-direction: column; padding: 70px 20px 60px; gap: 22px; }
	.proj-lightbox__media { flex: 0 0 auto; max-height: 55vh; }
	.proj-lightbox__panel { flex: 1; text-align: center; max-height: none; }
	.proj-lightbox__divider { margin-left: auto; margin-right: auto; }
	.proj-lightbox__prev { left: 12px; width: 40px; height: 40px; }
	.proj-lightbox__next { right: 12px; width: 40px; height: 40px; }
	.proj-lightbox__close { top: 12px; right: 12px; width: 40px; height: 40px; }
}
@media (max-width: 480px) {
	.proj-lightbox__nav { top: auto; bottom: 16px; transform: none; }
	.proj-lightbox__prev { left: 20px; }
	.proj-lightbox__next { right: 20px; }
	.proj-lightbox__counter { bottom: 70px; }
}
body.lightbox-open { overflow: hidden; }


/* =========================================================
   Single project page (single-ak_project.php)
   ========================================================= */
.project-single { background: var(--ak-bg); }

/* Hero */
.psingle-hero {
	position: relative;
	min-height: clamp(360px, 52vh, 560px);
	display: flex; align-items: flex-end;
	color: #fff;
	background: var(--ak-dark);
	background-size: cover;
	background-position: center;
	padding: 120px 0 64px;
	overflow: hidden;
}
.psingle-hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(20,15,12,.45) 0%, rgba(20,15,12,.25) 35%, rgba(20,15,12,.85) 100%);
}
.psingle-hero__inner { position: relative; z-index: 2; max-width: 940px; }
.psingle-hero__eyebrow {
	margin: 0 0 16px;
	font-size: 11px;
	letter-spacing: .34em;
	text-transform: uppercase;
	color: var(--ak-accent);
}
.psingle-hero__eyebrow span { position: relative; padding-left: 44px; }
.psingle-hero__eyebrow span::before {
	content: ""; position: absolute; left: 0; top: 50%;
	width: 32px; height: 1px; background: var(--ak-accent); opacity: .7;
}
.psingle-hero__title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: clamp(36px, 5.4vw, 76px);
	line-height: 1.04;
	letter-spacing: -.005em;
	margin: 0 0 18px;
	color: #fff;
}
.psingle-hero__loc {
	display: inline-flex; align-items: center; gap: 8px;
	color: rgba(255,255,255,.85);
	font-size: 14px;
	letter-spacing: .04em;
	margin: 0;
}
.psingle-hero__loc svg { color: var(--ak-accent); }

/* Breadcrumb */
.psingle-breadcrumb {
	padding: 22px 0 0;
	font-size: 12px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ak-ink-2, #6b5f53);
}
.psingle-breadcrumb ol {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; align-items: center; gap: 0 8px;
}
.psingle-breadcrumb li { display: flex; align-items: center; }
.psingle-breadcrumb li + li::before { content: "/"; margin-right: 10px; opacity: .45; }
.psingle-breadcrumb a { color: inherit; text-decoration: none; transition: color .25s ease; }
.psingle-breadcrumb a:hover { color: var(--ak-accent); }
.psingle-breadcrumb [aria-current="page"] { color: var(--ak-ink); }

/* Gallery (landscape main + thumb row) */
.psingle-gallery { padding: 36px 0 56px; }
.psingle-main {
	position: relative;
	background: var(--ak-bg-alt, #efe8de);
	overflow: hidden;
	border-radius: 2px;
	width: 80%;
	margin-inline: auto;
	/* Frame adapts to the image's natural size — no fixed crop. */
}
.psingle-main__img {
	width: 100%;
	height: auto;
	display: block;
	cursor: zoom-in;
	opacity: 1;
	transition: opacity .45s ease, transform .8s cubic-bezier(.22,.61,.36,1);
}
.psingle-main__img.is-swapping { opacity: 0; transform: scale(1.015); }
.psingle-main__status {
	position: absolute;
	top: 22px; left: 22px;
	background: rgba(193,154,91,.95);
	color: var(--ak-dark);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	padding: 7px 14px;
	z-index: 2;
}
.psingle-main__nav {
	position: absolute;
	top: 50%; transform: translateY(-50%);
	width: 48px; height: 48px;
	background: rgba(255,255,255,.96);
	border: 1px solid rgba(0,0,0,.08);
	color: var(--ak-ink);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	cursor: pointer;
	opacity: 0;
	transition: opacity .35s ease, background .25s ease, color .25s ease, transform .25s ease;
	z-index: 3;
	box-shadow: 0 6px 20px rgba(0,0,0,.1);
}
.psingle-main:hover .psingle-main__nav { opacity: 1; }
.psingle-main__nav:hover { background: var(--ak-accent); color: #fff; }
.psingle-main__prev { left: 18px; }
.psingle-main__next { right: 18px; }
.psingle-main__prev:hover { transform: translateY(-50%) translateX(-2px); }
.psingle-main__next:hover { transform: translateY(-50%) translateX(2px); }
@media (max-width: 640px) {
	.psingle-main__nav { opacity: 1; width: 40px; height: 40px; }
}

/* Thumbnails */
.psingle-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 18px;
}
.psingle-thumb {
	flex: 0 0 calc(12.5% - 11px); /* 8 thumbs per row at desktop */
	aspect-ratio: 4/3;
	background: var(--ak-bg-alt, #efe8de);
	border: 2px solid transparent;
	padding: 0;
	cursor: pointer;
	overflow: hidden;
	transition: border-color .3s ease, transform .3s ease;
	position: relative;
}
.psingle-thumb img {
	width: 100%; height: 100%;
	object-fit: cover; display: block;
	transition: transform .5s ease, opacity .25s ease;
}
.psingle-thumb:hover img { transform: scale(1.06); }
.psingle-thumb.is-active { border-color: var(--ak-accent); }
.psingle-thumb.is-active::after {
	content: "";
	position: absolute;
	inset: 0;
	border: 1px solid rgba(255,255,255,.4);
	pointer-events: none;
}
@media (max-width: 1100px) { .psingle-thumb { flex: 0 0 calc(16.66% - 10px); } }
@media (max-width: 800px)  { .psingle-thumb { flex: 0 0 calc(25% - 9px); } }
@media (max-width: 480px)  { .psingle-thumb { flex: 0 0 calc(33.33% - 8px); } }

/* Meta strip */
.psingle-meta {
	padding: 48px 0;
	border-top: 1px solid rgba(0,0,0,.06);
	border-bottom: 1px solid rgba(0,0,0,.06);
	background: #fff;
}
.psingle-meta__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 28px 40px;
	margin: 0;
}
.psingle-meta__grid > div { margin: 0; }
.psingle-meta__grid dt {
	font-size: 11px;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ak-ink-2, #9b8e80);
	margin: 0 0 8px;
}
.psingle-meta__grid dd {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: clamp(17px, 1.5vw, 20px);
	color: var(--ak-ink);
	margin: 0;
}
.psingle-meta__grid a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--ak-accent); transition: color .25s ease; }
.psingle-meta__grid a:hover { color: var(--ak-accent); }

/* Description */
.psingle-content {
	padding: clamp(60px, 7vw, 110px) 0;
}
.psingle-content .container.narrow { max-width: 760px; }
.psingle-content .entry-content {
	font-size: clamp(16px, 1.2vw, 18px);
	line-height: 1.85;
	color: var(--ak-ink-2, #4d4239);
}
.psingle-content .entry-content p { margin: 0 0 1.3em; }
.psingle-content .entry-content h2,
.psingle-content .entry-content h3 {
	font-family: var(--ak-font-serif);
	color: var(--ak-ink);
	margin: 2em 0 .6em;
	font-weight: 500;
}
.psingle-content .entry-content h2 { font-size: clamp(24px, 2.4vw, 32px); }
.psingle-content .entry-content h3 { font-size: clamp(20px, 1.8vw, 24px); }
.psingle-content .entry-content img { max-width: 100%; height: auto; margin: 1.5em 0; display: block; }

/* CTA strip */
.psingle-cta {
	background: var(--ak-dark);
	color: #fff;
	padding: clamp(60px, 7vw, 100px) 0;
}
.psingle-cta__inner {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 36px;
	align-items: center;
}
.psingle-cta__title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: clamp(28px, 3.4vw, 44px);
	line-height: 1.15;
	margin: 0 0 10px;
	color: #fff;
}
.psingle-cta__sub {
	color: rgba(255,255,255,.78);
	font-size: 15px;
	line-height: 1.6;
	margin: 0;
	max-width: 520px;
}
.psingle-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-self: end;
}
.psingle-cta__btn {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 30px;
	background: var(--ak-accent);
	color: #fff;
	font-size: 11px;
	letter-spacing: .26em;
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	transition: background .3s ease, color .3s ease, transform .3s ease;
	white-space: nowrap;
}
.psingle-cta__btn:hover { background: #fff; color: var(--ak-dark); transform: translateY(-1px); }
.psingle-cta__btn--ghost {
	background: transparent;
	color: #fff;
	border: 1px solid rgba(255,255,255,.4);
}
.psingle-cta__btn--ghost:hover { background: #fff; color: var(--ak-dark); border-color: #fff; }
@media (max-width: 800px) {
	.psingle-cta__inner { grid-template-columns: 1fr; }
	.psingle-cta__actions { justify-self: start; }
}

/* After-gallery custom content section (single-ak_project.php) */
.psingle-after-gallery {
	padding: clamp(40px, 5vw, 80px) 0 0;
}
.psingle-after-gallery .container.narrow { max-width: 820px; }
.psingle-after-gallery__content {
	font-size: clamp(16px, 1.2vw, 18px);
	line-height: 1.8;
	color: var(--ak-ink-2, #4d4239);
}
.psingle-after-gallery__content p { margin: 0 0 1.2em; }
.psingle-after-gallery__content h2,
.psingle-after-gallery__content h3,
.psingle-after-gallery__content h4 {
	font-family: var(--ak-font-serif);
	color: var(--ak-ink);
	font-weight: 500;
	margin: 1.8em 0 .6em;
}
.psingle-after-gallery__content h2 { font-size: clamp(24px, 2.2vw, 30px); }
.psingle-after-gallery__content h3 { font-size: clamp(20px, 1.8vw, 24px); }
.psingle-after-gallery__content h4 { font-size: clamp(18px, 1.5vw, 21px); }
.psingle-after-gallery__content ul,
.psingle-after-gallery__content ol { padding-left: 1.3em; margin: 0 0 1.3em; }
.psingle-after-gallery__content li { margin: 0 0 .4em; }
.psingle-after-gallery__content blockquote {
	border-left: 2px solid var(--ak-accent);
	padding: 6px 0 6px 22px;
	margin: 1.6em 0;
	font-family: var(--ak-font-serif);
	font-size: clamp(18px, 1.5vw, 22px);
	font-style: italic;
	color: var(--ak-ink);
}
.psingle-after-gallery__content img { max-width: 100%; height: auto; margin: 1.6em 0; display: block; }
.psingle-after-gallery__content a { color: var(--ak-accent); text-decoration: underline; text-underline-offset: 3px; }
.psingle-after-gallery__content a:hover { color: var(--ak-ink); }

/* Breadcrumb when placed above the hero */
.psingle-breadcrumb--top {
	padding: 32px 0 0;
	background: var(--ak-bg);
}

/* =========================================================
   Service enquiry form (single-ak_service.php)
   ========================================================= */
.svc-enquiry {
	padding: clamp(60px, 7vw, 110px) 0;
	background: #fff;
	border-top: 1px solid rgba(0,0,0,.05);
}
.svc-enquiry .container.narrow { max-width: 780px; }
.svc-enquiry__head { text-align: center; margin-bottom: 44px; }
.svc-enquiry__eyebrow {
	font-size: 11px;
	letter-spacing: .34em;
	text-transform: uppercase;
	color: var(--ak-accent);
	margin: 0 0 14px;
	position: relative;
	display: inline-block;
}
.svc-enquiry__eyebrow::before,
.svc-enquiry__eyebrow::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 28px;
	height: 1px;
	background: var(--ak-accent);
	opacity: .55;
}
.svc-enquiry__eyebrow::before { right: 100%; margin-right: 14px; }
.svc-enquiry__eyebrow::after  { left:  100%; margin-left:  14px; }
.svc-enquiry__title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: clamp(28px, 3.2vw, 44px);
	line-height: 1.15;
	margin: 0 0 14px;
	color: var(--ak-ink);
}
.svc-enquiry__sub {
	margin: 0;
	color: var(--ak-ink-2, #6b5f53);
	font-size: 15px;
	line-height: 1.6;
}

.svc-enquiry__alert {
	padding: 16px 22px;
	margin: 0 0 28px;
	font-size: 14px;
	line-height: 1.5;
	border-left: 3px solid;
}
.svc-enquiry__alert.is-success { background: #f3f9f1; color: #2c5b29; border-color: #67a35a; }
.svc-enquiry__alert.is-error   { background: #fdf2f0; color: #8a3a2b; border-color: #c95a3e; }

.svc-enquiry__form {
	background: #fbf7f0;
	padding: clamp(28px, 4vw, 48px);
	border: 1px solid rgba(0,0,0,.05);
}
.svc-enquiry__hp { position: absolute; left: -10000px; opacity: 0; height: 0; overflow: hidden; }
.svc-enquiry__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px 24px;
}
.svc-field { display: flex; flex-direction: column; }
.svc-field--full { grid-column: 1 / -1; }
.svc-field__label {
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--ak-ink-2, #6b5f53);
	margin-bottom: 8px;
	font-weight: 600;
}
.svc-field__label em { color: var(--ak-accent); font-style: normal; }
.svc-field input,
.svc-field textarea {
	width: 100%;
	border: 0;
	border-bottom: 1px solid rgba(0,0,0,.18);
	background: transparent;
	padding: 12px 0;
	font-size: 16px;
	color: var(--ak-ink);
	font-family: var(--ak-font-sans);
	transition: border-color .25s ease;
	resize: vertical;
}
.svc-field input:focus,
.svc-field textarea:focus {
	outline: none;
	border-color: var(--ak-accent);
}
.svc-field input:disabled { color: rgba(0,0,0,.3); }

.svc-enquiry__actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
	margin-top: 30px;
}
.svc-enquiry__submit {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 38px;
	background: var(--ak-ink);
	color: #fff;
	font-size: 11px;
	letter-spacing: .28em;
	text-transform: uppercase;
	font-weight: 600;
	border: 0;
	cursor: pointer;
	transition: background .3s ease, transform .3s ease, gap .3s ease;
}
.svc-enquiry__submit:hover { background: var(--ak-accent); gap: 14px; }
.svc-enquiry__fineprint {
	margin: 0;
	font-size: 12px;
	color: var(--ak-ink-2, #9b8e80);
	max-width: 360px;
	line-height: 1.5;
}
@media (max-width: 640px) {
	.svc-enquiry__grid { grid-template-columns: 1fr; }
	.svc-field--full { grid-column: 1; }
	.svc-enquiry__actions { justify-content: flex-start; }
}

/* =========================================================
   Mobile: center the logo (toggle on left + icons on right
   make the grid column visually off-center; pin branding
   to the exact center using absolute positioning).
   ========================================================= */
@media (max-width: 900px) {
	.header-inner { position: relative; }
	.site-branding {
		position: absolute;
		left: 50%;
		top: 50%;
		transform: translate(-50%, -50%);
		margin: 0;
		text-align: center;
		pointer-events: none; /* let the toggle/icons stay clickable around it */
	}
	.site-branding a,
	.site-branding .custom-logo-link,
	.site-branding img,
	.site-branding .custom-logo {
		pointer-events: auto;
		display: inline-block;
		margin: 0 auto;
	}
}

/* =========================================================
   Mobile optimisation (≤900px / ≤768px / ≤480px)
   Hard overflow guard, refined header/hero, reduced section
   padding, tighter typography, full-width buttons where natural.
   ========================================================= */

/* Hard overflow guard — prevents any rogue element from causing
   horizontal scroll on the whole document. */
html, body {
	overflow-x: clip;
	max-width: 100%;
}
/* Fallback for browsers without overflow: clip support */
@supports not (overflow: clip) {
	html, body { overflow-x: hidden; }
}

@media (max-width: 900px) {
	/* Container: tighter gutters, never exceeds viewport */
	.container {
		max-width: 100%;
		padding-left: 18px;
		padding-right: 18px;
		box-sizing: border-box;
	}

	/* Header: tighter, smaller logo */
	.header-inner { padding: 24px 17px; gap: 12px; }
	.custom-logo { max-height: 44px; }

	/* Hero: shorter, more legible title, balanced padding */
	.hero {
		min-height: clamp(440px, 78vh, 620px);
	}
	.hero-inner {
		padding-top: 32px;
		padding-bottom: 32px;
		max-width: 100%;
	}
	.hero-title {
		font-size: clamp(28px, 7.6vw, 44px);
		line-height: 1.12;
		margin-bottom: 22px;
		letter-spacing: -.005em;
	}
	.hero-eyebrow,
	.hero .eyebrow,
	.hero-sub {
		font-size: 11px !important;
		letter-spacing: .22em !important;
		margin-bottom: 18px;
	}

	/* Buttons: comfortable tap targets, not full-width */
	.btn, .btn-lg {
		padding: 15px 24px;
		font-size: 12px;
		letter-spacing: .2em;
	}
	.hero .btn { display: inline-flex; }

	/* Reduce section padding everywhere (overrides .section clamp) */
	.section, .section-alt {
		padding: 56px 0;
	}
	.section-head { margin-bottom: 32px; }

	/* Section titles: scale down */
	.section-title, .display, h2.display {
		font-size: clamp(26px, 6.5vw, 38px) !important;
		line-height: 1.15;
	}
	.section-sub { font-size: 15px; }

	/* Our-collection grid spacing */
	#our-collection { padding: 36px 0; }
	#our-collection .our-coll-eyebrow { font-size: clamp(22px, 5.5vw, 28px); }

	/* Testimonials premium block — reduce vertical chrome on mobile */
	.section-testimonials { padding: 64px 0; }
	.testimonial-slider { padding: 36px 16px; }

	/* Projects archive hero / single hero — already responsive but trim further */
	.proj-hero { min-height: clamp(280px, 42vh, 420px); }
	.proj-hero__inner { padding: 40px 0; }
	.proj-hero__title { font-size: clamp(30px, 8vw, 48px); line-height: 1.08; }
	.proj-hero__sub { font-size: 14px; }
	.proj-breadcrumb { font-size: 11px; letter-spacing: .14em; margin-bottom: 22px; }

	/* Project / service single page gallery */
	.psingle-thumbs { gap: 8px; }
	.psingle-meta { padding: 32px 0; }
	.psingle-meta__grid { gap: 18px 24px; }
	.psingle-cta__inner { grid-template-columns: 1fr; gap: 24px; }
	.psingle-cta__actions { flex-direction: column; align-items: stretch; }
	.psingle-cta__btn { justify-content: center; }

	/* Service enquiry form */
	.svc-enquiry { padding: 56px 0; }
	.svc-enquiry__form { padding: 22px; }
	.svc-enquiry__grid { grid-template-columns: 1fr; gap: 14px; }
	.svc-field--full { grid-column: 1; }

	/* Footer chunks */
	.site-footer { padding-top: 48px; }
}

@media (max-width: 480px) {
	.container { padding-left: 14px; padding-right: 14px; }
	.header-inner { padding: 26px 12px; }
	.custom-logo { max-height: 40px; }

	.hero { min-height: 70vh; }
	.hero-title { font-size: clamp(26px, 8vw, 38px); }

	.section, .section-alt { padding: 44px 0; }
	.section-title, .display { font-size: clamp(24px, 7.5vw, 32px) !important; }

	/* CTA stacking */
	.section-cta .btn { display: block; text-align: center; }
}

/* =========================================================
   Premium Navigation — Desktop dropdown + Mobile drawer
   Replaces previous nav defaults. Works with the new
   .nav-close, .nav-backdrop, .submenu-toggle elements.
   ========================================================= */

/* Reset list defaults for sub-menus (no bullets, no padding) */
.primary-menu ul,
.primary-menu .sub-menu {
	list-style: none;
	padding: 0;
	margin: 0;
}
.primary-menu .sub-menu li { display: block; }

/* Hide close button on desktop; only shown when menu is in drawer mode */
.nav-close {
	display: none;
	background: transparent;
	border: 1px solid rgba(0,0,0,.12);
	color: var(--ak-ink);
	width: 42px;
	height: 42px;
	border-radius: 50%;
	cursor: pointer;
	align-items: center;
	justify-content: center;
	transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
}
.nav-close:hover {
	background: var(--ak-ink);
	color: #fff;
	border-color: var(--ak-ink);
	transform: rotate(90deg);
}

/* Backdrop — hidden on desktop, used by mobile drawer */
.nav-backdrop {
	position: fixed; inset: 0;
	background: rgba(20,15,12,.55);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity .4s ease, visibility 0s linear .4s;
	z-index: 90;
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
}
.nav-backdrop.is-visible {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transition: opacity .4s ease;
}

/* Hamburger → X transformation */
.menu-toggle .bar {
	transform-origin: center;
	transition: transform .35s cubic-bezier(.22,.61,.36,1), opacity .25s ease;
}
.menu-toggle.is-open .bar:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.menu-toggle.is-open .bar:nth-child(2) { opacity: 0; transform: scaleX(.4); }
.menu-toggle.is-open .bar:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

/* Submenu toggle button — injected by JS into items with sub-menus.
   Hidden on desktop (CSS hover handles it), shown on mobile. */
.submenu-toggle {
	display: none;
	background: transparent;
	border: 0;
	cursor: pointer;
	color: var(--ak-ink-2, #6b5f53);
	padding: 8px;
}

/* ============ DESKTOP DROPDOWN (>860px) ============ */
@media (min-width: 861px) {
	.primary-menu > li { position: relative; }
	.primary-menu .sub-menu {
		position: absolute;
		top: calc(100% + 18px);
		left: 50%;
		transform: translateX(-50%) translateY(-8px);
		min-width: 240px;
		background: #fff;
		border: 1px solid rgba(0,0,0,.05);
		box-shadow: 0 18px 50px -10px rgba(20,15,12,.16), 0 4px 14px rgba(20,15,12,.06);
		padding: 12px 0;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition: opacity .28s ease, transform .35s cubic-bezier(.22,.61,.36,1), visibility 0s linear .35s;
		z-index: 60;
	}
	.primary-menu .sub-menu::before {
		content: "";
		position: absolute;
		top: -6px;
		left: 50%;
		transform: translateX(-50%) rotate(45deg);
		width: 12px; height: 12px;
		background: #fff;
		border-left: 1px solid rgba(0,0,0,.05);
		border-top: 1px solid rgba(0,0,0,.05);
	}
	.primary-menu li:hover > .sub-menu,
	.primary-menu li:focus-within > .sub-menu {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translateX(-50%) translateY(0);
		transition: opacity .28s ease, transform .35s cubic-bezier(.22,.61,.36,1);
	}
	/* Bridge the gap so dropdown doesn't close while mouse travels */
	.primary-menu > li.menu-item-has-children::after {
		content: "";
		position: absolute;
		top: 100%; left: 0; right: 0;
		height: 22px;
	}
	.primary-menu .sub-menu a {
		display: block;
		padding: 11px 28px;
		font-size: 11px;
		letter-spacing: .22em;
		text-transform: uppercase;
		color: var(--ak-ink);
		font-weight: 500;
		white-space: nowrap;
		transition: background .2s ease, color .2s ease, padding-left .25s ease;
	}
	.primary-menu .sub-menu a::after { display: none !important; }
	.primary-menu .sub-menu a:hover {
		background: rgba(193,154,91,.08);
		color: var(--ak-accent);
		padding-left: 34px;
	}
	/* Dropdown chevron next to parent labels */
	.primary-menu > li.menu-item-has-children > a {
		display: inline-flex;
		align-items: center;
		gap: 6px;
	}
	.primary-menu > li.menu-item-has-children > a::before {
		content: "";
		display: inline-block;
		width: 8px; height: 8px;
		margin-left: 8px;
		border-right: 1.5px solid currentColor;
		border-bottom: 1.5px solid currentColor;
		transform: rotate(45deg) translate(-2px, -2px);
		transition: transform .3s ease;
		order: 2;
	}
	.primary-menu > li.menu-item-has-children:hover > a::before {
		transform: rotate(225deg) translate(-2px, -2px);
	}
}

/* ============ MOBILE DRAWER (≤860px) ============ */
@media (max-width: 860px) {
	.main-navigation {
		position: fixed;
		top: 0; right: 0;
		bottom: 0;
		width: min(440px, 92vw);
		background: var(--ak-bg);
		transform: translateX(100%);
		transition: transform .55s cubic-bezier(.22,.61,.36,1);
		display: flex;
		flex-direction: column;
		padding: 88px 0 40px;
		z-index: 100;
		box-shadow: -10px 0 50px -10px rgba(20,15,12,.18);
		overflow-y: auto;
		overflow-x: hidden;
		visibility: hidden;
	}
	.main-navigation.is-open {
		transform: translateX(0);
		visibility: visible;
	}
	.nav-close {
		display: inline-flex;
		position: absolute;
		top: 22px;
		right: 22px;
		z-index: 5;
	}
	body.nav-open { overflow: hidden; }

	.primary-menu {
		flex-direction: column;
		gap: 0;
		width: 100%;
		padding: 0;
		margin: 0;
		display: block;
	}
	.primary-menu > li {
		position: relative;
		border-bottom: 1px solid rgba(0,0,0,.06);
		padding: 0 28px;
	}
	.primary-menu > li:first-child { border-top: 1px solid rgba(0,0,0,.06); }
	.primary-menu > li > a {
		display: block;
		padding: 20px 0;
		font-size: 13px;
		letter-spacing: .26em;
		text-transform: uppercase;
		color: var(--ak-ink);
		font-weight: 500;
		font-family: var(--ak-font-sans);
		transition: color .25s ease, padding-left .35s ease;
	}
	.primary-menu > li:hover > a,
	.primary-menu > li.is-expanded > a {
		color: var(--ak-accent);
		padding-left: 4px;
	}
	.primary-menu a::after { display: none; }

	/* Submenu toggle chevron */
	.submenu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		position: absolute;
		top: 12px;
		right: 22px;
		width: 38px;
		height: 38px;
		border-radius: 50%;
		color: var(--ak-ink);
		transition: background .25s ease, transform .35s ease, color .25s ease;
	}
	.submenu-toggle:hover { background: rgba(0,0,0,.04); }
	.submenu-toggle svg { transition: transform .4s cubic-bezier(.22,.61,.36,1); }
	.primary-menu li.is-expanded > .submenu-toggle { color: var(--ak-accent); }
	.primary-menu li.is-expanded > .submenu-toggle svg { transform: rotate(180deg); }

	/* Sub-menu accordion (mobile) */
	.primary-menu .sub-menu {
		max-height: 0;
		overflow: hidden;
		transition: max-height .45s cubic-bezier(.22,.61,.36,1), padding .35s ease;
		padding: 0 0 0 14px;
		border-left: 1px solid rgba(193,154,91,.4);
		margin: 0 0 0 4px;
	}
	.primary-menu li.is-expanded > .sub-menu {
		max-height: 600px;
		padding: 4px 0 18px 14px;
	}
	.primary-menu .sub-menu a {
		display: block;
		padding: 10px 0;
		font-size: 11px;
		letter-spacing: .2em;
		text-transform: uppercase;
		color: var(--ak-ink-2, #6b5f53);
		font-weight: 500;
		transition: color .2s ease, padding-left .25s ease;
	}
	.primary-menu .sub-menu a:hover {
		color: var(--ak-accent);
		padding-left: 6px;
	}

	/* Stagger items in from right when drawer opens */
	.main-navigation.is-open .primary-menu > li {
		animation: navItemIn .5s cubic-bezier(.22,.61,.36,1) both;
	}
	.main-navigation.is-open .primary-menu > li:nth-child(1) { animation-delay: .12s; }
	.main-navigation.is-open .primary-menu > li:nth-child(2) { animation-delay: .18s; }
	.main-navigation.is-open .primary-menu > li:nth-child(3) { animation-delay: .24s; }
	.main-navigation.is-open .primary-menu > li:nth-child(4) { animation-delay: .30s; }
	.main-navigation.is-open .primary-menu > li:nth-child(5) { animation-delay: .36s; }
	.main-navigation.is-open .primary-menu > li:nth-child(6) { animation-delay: .42s; }
	.main-navigation.is-open .primary-menu > li:nth-child(7) { animation-delay: .48s; }
	.main-navigation.is-open .primary-menu > li:nth-child(n+8) { animation-delay: .54s; }
}
@keyframes navItemIn {
	from { opacity: 0; transform: translateX(20px); }
	to   { opacity: 1; transform: translateX(0); }
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
	.main-navigation,
	.primary-menu > li,
	.primary-menu .sub-menu,
	.submenu-toggle svg,
	.menu-toggle .bar {
		transition: none !important;
		animation: none !important;
	}
}

/* =========================================================
   Footer — clean 4-column layout (.site-footer--clean)
   Overrides the older footer-grid/contact/base structure.
   ========================================================= */
.site-footer--clean {
	background: var(--ak-dark);
	color: rgba(255,255,255,.78);
	padding: clamp(64px, 7vw, 110px) 0 0;
	margin-top: 0;
}
.site-footer--clean a { color: rgba(255,255,255,.78); text-decoration: none; transition: color .25s ease; }
.site-footer--clean a:hover { color: var(--ak-accent); }

.footer-grid-4 {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1.3fr;
	gap: 48px 56px;
	padding-bottom: clamp(48px, 5vw, 80px);
}
@media (max-width: 1024px) {
	.footer-grid-4 { grid-template-columns: 1fr 1fr; gap: 44px 40px; }
}
@media (max-width: 540px) {
	.footer-grid-4 { grid-template-columns: 1fr; gap: 40px; }
}

/* Column titles */
.footer-col__title {
	font-family: var(--ak-font-sans);
	font-size: 11px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: #fff;
	margin: 0 0 22px;
	font-weight: 600;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(255,255,255,.12);
	position: relative;
}
.footer-col__title::after {
	content: "";
	position: absolute;
	bottom: -1px; left: 0;
	width: 28px;
	height: 1px;
	background: var(--ak-accent);
}

/* Column 1: Brand */
.footer-col--brand .footer-brand {
	margin-bottom: 20px;
	display: flex;
	align-items: center;
}
.footer-col--brand .footer-brand .custom-logo {
	max-height: 56px;
	width: auto;
	filter: brightness(0) invert(1);
	opacity: .92;
}
.footer-col--brand .footer-brand .custom-logo-link {
	display: inline-block;
	background: rgba(255,255,255,.04);
	padding: 8px 14px;
	border: 1px solid rgba(255,255,255,.08);
}
.footer-col--brand .footer-brand__name {
	font-family: var(--ak-font-serif);
	font-size: 26px;
	font-weight: 500;
	color: #fff;
	letter-spacing: .02em;
}
.footer-about {
	font-size: 14px;
	line-height: 1.75;
	color: rgba(255,255,255,.7);
	margin: 0 0 26px;
	max-width: 340px;
}

/* Social icons row */
.footer-socials {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	gap: 10px;
}
.footer-socials a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	color: rgba(255,255,255,.78);
	background: rgba(255,255,255,.05);
	border: 1px solid rgba(255,255,255,.1);
	transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
}
.footer-socials a:hover {
	background: var(--ak-accent);
	color: #fff;
	border-color: var(--ak-accent);
	transform: translateY(-2px);
}

/* Menu columns */
.site-footer--clean .footer-menu {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.site-footer--clean .footer-menu a {
	font-size: 14px;
	line-height: 1.5;
	color: rgba(255,255,255,.7);
	transition: color .25s ease, padding-left .3s ease;
	display: inline-block;
}
.site-footer--clean .footer-menu a:hover {
	color: var(--ak-accent);
	padding-left: 6px;
}

/* Newsletter */
.footer-newsletter__intro {
	font-size: 14px;
	line-height: 1.65;
	color: rgba(255,255,255,.7);
	margin: 0 0 22px;
}
.footer-newsletter__row {
	display: flex;
	align-items: stretch;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.12);
	overflow: hidden;
	transition: border-color .25s ease, background .25s ease;
}
.footer-newsletter__row:focus-within {
	border-color: var(--ak-accent);
	background: rgba(255,255,255,.1);
}
.footer-newsletter input[type=email] {
	background: transparent;
	border: 0;
	flex: 1;
	padding: 14px 16px;
	color: #fff;
	font-size: 14px;
	font-family: var(--ak-font-sans);
	min-width: 0;
}
.footer-newsletter input[type=email]:focus { outline: none; }
.footer-newsletter input[type=email]::placeholder { color: rgba(255,255,255,.45); }
.footer-newsletter button[type=submit] {
	background: var(--ak-accent);
	border: 0;
	color: #fff;
	width: 50px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background .25s ease;
}
.footer-newsletter button[type=submit]:hover { background: #fff; color: var(--ak-dark); }
.footer-newsletter__msg {
	margin: 14px 0 0;
	padding: 10px 14px;
	font-size: 13px;
}
.footer-newsletter__msg.is-success {
	background: rgba(193,154,91,.15);
	color: var(--ak-accent);
	border-left: 2px solid var(--ak-accent);
}
.footer-newsletter__msg.is-error {
	background: rgba(201,90,62,.12);
	color: #e89986;
	border-left: 2px solid #c95a3e;
}

/* Base bar */
.site-footer--clean .footer-base {
	border-top: 1px solid rgba(255,255,255,.08);
	padding: 22px 0;
	margin-top: 0;
}
.footer-base__inner {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
	justify-content: space-between;
}
.footer-base__copy {
	margin: 0;
	font-size: 12px;
	color: rgba(255,255,255,.55);
	letter-spacing: .04em;
}
.footer-base__legal {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	gap: 24px;
}
.footer-base__legal a {
	font-size: 12px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: rgba(255,255,255,.55);
}
@media (max-width: 540px) {
	.footer-base__inner { flex-direction: column; align-items: flex-start; gap: 12px; }
	.footer-base__legal { flex-wrap: wrap; gap: 16px; }
}

/* Make sure the old footer-grid/contact CSS does not interfere when the
   page renders the new clean footer (the .site-footer--clean class scopes
   our new rules and the new markup has its own structure). */

/* Mobile drawer logo — shown at the top of the slide-in menu */
.nav-brand { display: none; }
@media (max-width: 860px) {
	.nav-brand {
		display: flex;
		justify-content: center;
		align-items: center;
		padding: 8px 28px 32px;
		border-bottom: 1px solid rgba(0,0,0,.06);
		margin: 0 0 18px;
	}
	.nav-brand__link {
		display: inline-flex;
		align-items: center;
		text-decoration: none;
	}
	.nav-brand__logo {
		max-height: 56px;
		width: auto;
		display: block;
	}
	.nav-brand__name {
		font-family: var(--ak-font-serif);
		font-size: 22px;
		font-weight: 500;
		color: var(--ak-ink);
		letter-spacing: .02em;
	}
	/* Tighten drawer top padding now that the brand sits there */
	.main-navigation { padding-top: 70px; }
}

/* =========================================================
   Floating contact stack — fixed bottom-left, single column
   ========================================================= */
.float-contact {
	position: fixed;
	left: 20px;
	bottom: 20px;
	z-index: 80;
	display: flex;
	flex-direction: column;
	gap: 12px;
	pointer-events: none;
}
.float-contact__btn {
	pointer-events: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	color: #fff;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.12);
	transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.float-contact__btn:hover {
	transform: translateY(-3px) scale(1.05);
	box-shadow: 0 12px 30px rgba(0,0,0,.22), 0 3px 8px rgba(0,0,0,.14);
}
.float-contact__btn--call {
	background: var(--ak-accent);
}
.float-contact__btn--call:hover { background: var(--ak-ink); }
.float-contact__btn--wa {
	background: #25d366; /* WhatsApp brand green */
}
.float-contact__btn--wa:hover { background: #128c7e; }

@media (max-width: 540px) {
	.float-contact {
		left: 14px;
		bottom: 14px;
		gap: 10px;
	}
	.float-contact__btn {
		width: 46px;
		height: 46px;
	}
}

/* =========================================================
   404 — premium not-found page
   ========================================================= */
.e404-wrap { background: var(--ak-bg); }
.e404 {
	padding: clamp(80px, 9vw, 140px) 0 clamp(64px, 7vw, 110px);
	position: relative;
	overflow: hidden;
}
.e404__inner {
	max-width: 920px;
	margin: 0 auto;
	text-align: center;
	position: relative;
}

/* Giant 404 numerals */
.e404__numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(8px, 1.5vw, 20px);
	margin-bottom: 36px;
	color: var(--ak-ink);
	line-height: 1;
	user-select: none;
}
.e404__digit {
	font-family: var(--ak-font-serif);
	font-weight: 400;
	font-size: clamp(120px, 22vw, 260px);
	letter-spacing: -.04em;
	background: linear-gradient(160deg, var(--ak-ink) 0%, var(--ak-ink-2, #6b5f53) 60%, var(--ak-accent) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	line-height: .85;
}
.e404__zero {
	display: inline-flex;
	width: clamp(120px, 22vw, 260px);
	height: clamp(120px, 22vw, 260px);
	color: var(--ak-accent);
	animation: e404Spin 30s linear infinite;
}
@keyframes e404Spin { to { transform: rotate(360deg); } }

/* Head */
.e404__head { margin-bottom: 36px; }
.e404__eyebrow {
	font-size: 11px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--ak-accent);
	margin: 0 0 18px;
	display: inline-block;
	position: relative;
}
.e404__eyebrow span { position: relative; padding: 0 32px; }
.e404__eyebrow span::before,
.e404__eyebrow span::after {
	content: "";
	position: absolute; top: 50%;
	width: 24px; height: 1px;
	background: var(--ak-accent);
	opacity: .6;
}
.e404__eyebrow span::before { right: 100%; }
.e404__eyebrow span::after  { left: 100%; }
.e404__title {
	font-family: var(--ak-font-serif);
	font-weight: 400;
	font-size: clamp(28px, 4vw, 48px);
	line-height: 1.15;
	color: var(--ak-ink);
	margin: 0 0 16px;
	letter-spacing: -.005em;
}
.e404__sub {
	font-size: clamp(15px, 1.2vw, 17px);
	line-height: 1.65;
	color: var(--ak-ink-2, #6b5f53);
	max-width: 560px;
	margin: 0 auto 32px;
}

/* Search */
.e404__search {
	display: flex;
	align-items: stretch;
	max-width: 480px;
	margin: 0 auto 28px;
	background: #fff;
	border: 1px solid rgba(0,0,0,.1);
	transition: border-color .25s ease, box-shadow .25s ease;
}
.e404__search:focus-within {
	border-color: var(--ak-accent);
	box-shadow: 0 0 0 4px rgba(193,154,91,.1);
}
.e404__search svg {
	flex-shrink: 0;
	color: var(--ak-ink-2);
	align-self: center;
	margin: 0 8px 0 16px;
}
.e404__search input {
	background: transparent;
	border: 0;
	padding: 14px 12px 14px 0;
	font-size: 14px;
	flex: 1;
	min-width: 0;
	color: var(--ak-ink);
	font-family: var(--ak-font-sans);
}
.e404__search input:focus { outline: none; }
.e404__search button {
	background: var(--ak-ink);
	color: #fff;
	border: 0;
	padding: 0 22px;
	font-size: 11px;
	letter-spacing: .24em;
	text-transform: uppercase;
	font-weight: 600;
	cursor: pointer;
	transition: background .25s ease;
}
.e404__search button:hover { background: var(--ak-accent); }

/* Action buttons */
.e404__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	margin-bottom: clamp(50px, 6vw, 80px);
}
.e404__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 30px;
	font-size: 11px;
	letter-spacing: .28em;
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	transition: background .25s ease, color .25s ease, border-color .25s ease, gap .3s ease;
	white-space: nowrap;
}
.e404__btn--primary {
	background: var(--ak-accent);
	color: #fff;
}
.e404__btn--primary:hover { background: var(--ak-ink); }
.e404__btn--ghost {
	background: transparent;
	color: var(--ak-ink);
	border: 1px solid var(--ak-ink);
}
.e404__btn--ghost:hover { background: var(--ak-ink); color: #fff; gap: 14px; }

/* Suggested projects */
.e404__suggest {
	border-top: 1px solid rgba(0,0,0,.08);
	padding-top: 48px;
	margin-top: 16px;
}
.e404__suggest-label {
	font-size: 11px;
	letter-spacing: .32em;
	text-transform: uppercase;
	color: var(--ak-ink-2, #6b5f53);
	margin: 0 0 24px;
}
.e404__suggest-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	text-align: left;
}
@media (max-width: 720px) {
	.e404__suggest-grid { grid-template-columns: 1fr; }
}
.e404__suggest-card {
	display: block;
	text-decoration: none;
	color: inherit;
	transition: transform .35s cubic-bezier(.22,.61,.36,1);
}
.e404__suggest-card:hover { transform: translateY(-4px); }
.e404__suggest-thumb {
	aspect-ratio: 4/3;
	background: var(--ak-bg-alt, #efe8de) center/cover no-repeat;
	margin-bottom: 12px;
	overflow: hidden;
	position: relative;
}
.e404__suggest-thumb::after {
	content: "";
	position: absolute;
	inset: 14px;
	border: 1px solid rgba(255,255,255,0);
	transition: border-color .35s ease;
}
.e404__suggest-card:hover .e404__suggest-thumb::after { border-color: rgba(255,255,255,.9); }
.e404__suggest-meta { padding: 0 4px; }
.e404__suggest-title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.3;
	margin: 0 0 4px;
	color: var(--ak-ink);
	transition: color .25s ease;
}
.e404__suggest-card:hover .e404__suggest-title { color: var(--ak-accent); }
.e404__suggest-loc {
	font-size: 11px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--ak-ink-2, #9b8e80);
	margin: 0;
}

@media (max-width: 540px) {
	.e404__zero { width: 110px; height: 110px; }
	.e404__digit { font-size: 110px; }
	.e404__numbers { gap: 2px; }
}

/* =========================================================
   404 — "Not found" page
   ========================================================= */
.e404-wrap { background: var(--ak-bg); }
.e404 {
	padding: clamp(80px, 9vw, 140px) 0 clamp(80px, 9vw, 140px);
	text-align: center;
}
.e404__inner { max-width: 880px; margin: 0 auto; }

/* Giant 404 numerals */
.e404__numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(12px, 2vw, 28px);
	margin: 0 0 36px;
	color: var(--ak-accent);
	opacity: .85;
}
.e404__digit {
	font-family: var(--ak-font-serif);
	font-weight: 400;
	font-size: clamp(80px, 14vw, 180px);
	line-height: .9;
	color: var(--ak-ink);
}
.e404__zero {
	width: clamp(80px, 14vw, 180px);
	height: clamp(80px, 14vw, 180px);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	animation: e404spin 28s linear infinite;
}
@keyframes e404spin { to { transform: rotate(360deg); } }

/* Head */
.e404__head { margin: 0 auto 30px; max-width: 640px; }
.e404__eyebrow {
	margin: 0 0 16px;
	font-size: 11px;
	letter-spacing: .32em;
	text-transform: uppercase;
	color: var(--ak-accent);
}
.e404__eyebrow span {
	display: inline-block;
	padding-bottom: 8px;
	border-bottom: 1px solid rgba(193,154,91,.55);
}
.e404__title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: clamp(28px, 4.4vw, 52px);
	line-height: 1.12;
	color: var(--ak-ink);
	margin: 0 0 14px;
}
.e404__sub {
	font-size: clamp(15px, 1.3vw, 17px);
	line-height: 1.7;
	color: var(--ak-ink-2, #6b5f53);
	margin: 0;
}

/* Search */
.e404__search {
	display: flex;
	align-items: stretch;
	max-width: 480px;
	margin: 36px auto 28px;
	background: #fff;
	border: 1px solid rgba(0,0,0,.1);
	border-radius: 999px;
	padding: 0 18px;
	transition: border-color .25s ease;
}
.e404__search:focus-within { border-color: var(--ak-ink); }
.e404__search svg { align-self: center; color: var(--ak-ink-2); flex-shrink: 0; }
.e404__search input[type=search] {
	flex: 1;
	background: transparent;
	border: 0;
	padding: 14px 0 14px 12px;
	font-size: 14px;
	color: var(--ak-ink);
	font-family: var(--ak-font-sans);
}
.e404__search input[type=search]:focus { outline: none; }
.e404__search input[type=search]::placeholder { color: rgba(0,0,0,.4); }
.e404__search button {
	background: transparent;
	border: 0;
	color: var(--ak-ink);
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 600;
	padding: 0 6px;
	cursor: pointer;
	transition: color .25s ease;
}
.e404__search button:hover { color: var(--ak-accent); }

/* Action buttons */
.e404__actions {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px;
	margin: 8px 0 0;
}
.e404__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 30px;
	font-size: 11px;
	letter-spacing: .26em;
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	transition: background .3s ease, color .3s ease, border-color .3s ease, gap .3s ease;
	white-space: nowrap;
}
.e404__btn--primary {
	background: var(--ak-ink);
	color: #fff;
	border: 1px solid var(--ak-ink);
}
.e404__btn--primary:hover { background: var(--ak-accent); border-color: var(--ak-accent); gap: 16px; }
.e404__btn--ghost {
	background: transparent;
	color: var(--ak-ink);
	border: 1px solid rgba(0,0,0,.18);
}
.e404__btn--ghost:hover { background: var(--ak-ink); color: #fff; border-color: var(--ak-ink); gap: 16px; }

/* Suggested projects */
.e404__suggest { margin-top: 70px; }
.e404__suggest-label {
	font-size: 11px;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ak-ink-2);
	margin: 0 0 24px;
}
.e404__suggest-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	max-width: 760px;
	margin: 0 auto;
}
@media (max-width: 700px) { .e404__suggest-grid { grid-template-columns: 1fr; gap: 14px; } }
.e404__suggest-card {
	display: block;
	text-decoration: none;
	color: inherit;
	background: #fff;
	overflow: hidden;
	transition: transform .35s ease, box-shadow .35s ease;
}
.e404__suggest-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 14px 30px -6px rgba(20,15,12,.12);
}
.e404__suggest-thumb {
	aspect-ratio: 4/3;
	background: var(--ak-bg-alt, #efe8de);
	background-size: cover;
	background-position: center;
}
.e404__suggest-meta { padding: 14px 16px 18px; text-align: left; }
.e404__suggest-title {
	font-family: var(--ak-font-serif);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.3;
	color: var(--ak-ink);
	margin: 0 0 4px;
}
.e404__suggest-loc {
	font-size: 11px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--ak-ink-2);
	margin: 0;
}

@media (max-width: 600px) {
	.e404 { padding: 64px 0; }
	.e404__suggest { margin-top: 48px; }
}

/* =========================================================
   Blog — Journal listing + single post (premium)
   ========================================================= */
.blog-page { background: var(--ak-bg); }
.blog-wrap { padding: clamp(56px, 6vw, 96px) 0 clamp(70px, 8vw, 120px); }

/* Listing grid */
.blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(24px, 3vw, 40px);
}
@media (max-width: 980px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card { display: flex; flex-direction: column; background: #fff; border: 1px solid rgba(0,0,0,.05); overflow: hidden; transition: transform .4s cubic-bezier(.22,.61,.36,1), box-shadow .4s ease; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -18px rgba(20,15,12,.18); }
.blog-card__media { display: block; position: relative; aspect-ratio: 3/2; overflow: hidden; background: var(--ak-bg-alt, #efe8de); }
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .7s cubic-bezier(.22,.61,.36,1); }
.blog-card:hover .blog-card__media img { transform: scale(1.05); }
.blog-card__body { padding: 24px 24px 28px; display: flex; flex-direction: column; flex: 1; }
.blog-card__cat { font-size: 10px; letter-spacing: .28em; text-transform: uppercase; color: var(--ak-accent); margin: 0 0 12px; }
.blog-card__title { font-family: var(--ak-font-serif); font-weight: 500; font-size: clamp(19px, 1.5vw, 23px); line-height: 1.3; margin: 0 0 10px; letter-spacing: -.005em; }
.blog-card__title a { color: var(--ak-ink); text-decoration: none; transition: color .25s ease; }
.blog-card__title a:hover { color: var(--ak-accent); }
.blog-card__meta { font-size: 12px; letter-spacing: .04em; color: var(--ak-ink-2, #9b8e80); margin: 0 0 14px; }
.blog-card__excerpt { font-size: 14px; line-height: 1.7; color: var(--ak-ink-2, #6b5f53); margin: 0 0 18px; }
.blog-card__more { margin-top: auto; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--ak-ink); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: gap .3s ease, color .25s ease; }
.blog-card__more:hover { color: var(--ak-accent); gap: 13px; }

.blog-empty { text-align: center; color: var(--ak-ink-2); padding: 60px 0; }

/* Pagination (shared look) */
.blog-pagination { margin-top: 56px; text-align: center; }
.blog-pagination .nav-links { display: inline-flex; gap: 6px; flex-wrap: wrap; justify-content: center; }
.blog-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px; border: 1px solid rgba(0,0,0,.12); color: var(--ak-ink); text-decoration: none; font-size: 13px; transition: background .25s, color .25s, border-color .25s; }
.blog-pagination .page-numbers:hover { border-color: var(--ak-ink); }
.blog-pagination .page-numbers.current { background: var(--ak-ink); color: #fff; border-color: var(--ak-ink); }

/* Single post */
.singlepost-wrap { padding: clamp(40px, 5vw, 72px) 0 clamp(70px, 8vw, 120px); }
.singlepost { max-width: 820px; margin: 0 auto; }
.singlepost__featured { margin: 0 0 clamp(28px, 4vw, 48px); }
.singlepost__featured img { width: 100%; height: auto; display: block; }
.singlepost__content { font-size: clamp(16px, 1.2vw, 18px); line-height: 1.85; color: var(--ak-ink-2, #4d4239); }
.singlepost__content > *:first-child { margin-top: 0; }
.singlepost__content p { margin: 0 0 1.3em; }
.singlepost__content h2 { font-family: var(--ak-font-serif); font-weight: 500; font-size: clamp(24px, 2.4vw, 34px); color: var(--ak-ink); margin: 1.8em 0 .5em; letter-spacing: -.005em; }
.singlepost__content h3 { font-family: var(--ak-font-serif); font-weight: 500; font-size: clamp(20px, 1.9vw, 26px); color: var(--ak-ink); margin: 1.5em 0 .4em; }
.singlepost__content img { max-width: 100%; height: auto; margin: 1.6em 0; display: block; }
.singlepost__content blockquote { border-left: 2px solid var(--ak-accent); padding: 6px 0 6px 24px; margin: 1.8em 0; font-family: var(--ak-font-serif); font-style: italic; font-size: clamp(19px, 1.6vw, 24px); color: var(--ak-ink); }
.singlepost__content a { color: var(--ak-accent); text-decoration: underline; text-underline-offset: 3px; }
.singlepost__content ul, .singlepost__content ol { margin: 0 0 1.4em; padding-left: 1.4em; }
.singlepost__content li { margin: 0 0 .5em; }
.singlepost__tags { margin: 40px 0 0; padding-top: 24px; border-top: 1px solid rgba(0,0,0,.08); display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.singlepost__tags .tag-label { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--ak-ink-2, #9b8e80); margin-right: 6px; }
.singlepost__tags a { font-size: 12px; letter-spacing: .04em; color: var(--ak-ink); text-decoration: none; border: 1px solid rgba(0,0,0,.14); padding: 6px 14px; border-radius: 999px; transition: background .25s, color .25s, border-color .25s; }
.singlepost__tags a:hover { background: var(--ak-accent); color: #fff; border-color: var(--ak-accent); }
.singlepost__nav { max-width: 820px; margin: 48px auto 0; display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.singlepost__nav a { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--ak-ink); text-decoration: none; transition: color .25s ease; max-width: 46%; }
.singlepost__nav a:hover { color: var(--ak-accent); }
.singlepost__nav .nav-prev::before { content: "← "; }
.singlepost__nav .nav-next::after { content: " →"; }
.singlepost__back { display: inline-flex; align-items: center; gap: 8px; margin-top: 40px; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--ak-ink); text-decoration: none; }
.singlepost__back:hover { color: var(--ak-accent); }

/* Section head with a right-aligned "View All" action (Collections etc.) */
.section-head--with-action {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	text-align: left;
	max-width: none;
}
.section-head--with-action .section-head__text { flex: 1; }
.section-head__action {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 13px 26px;
	background: #b08d57;
	color: #fff;
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	transition: background .3s ease, gap .3s ease, transform .3s ease;
}
.section-head__action:hover { background: #2a201a; color: #fff; gap: 14px; transform: translateY(-1px); }
@media (max-width: 700px) {
	.section-head--with-action { flex-direction: column; align-items: center; text-align: center; }
	.section-head--with-action .section-head__text { width: 100%; }
}

/* Tighten the gap between Home About and the Collections section */
.front-main #collections.section-collections { padding-top: clamp(20px, 3vw, 40px); }

/* =========================================================
   Global button style — white bg + black text → dark (#2a201a) bg + white text on hover
   Applies to all CTA/text buttons. WhatsApp keeps its brand green.
   ========================================================= */
.btn:not(.btn-whatsapp),
.btn-primary,
.btn-secondary,
.btn-outline,
.btn-link,
.btn-banner,
.home-about__btn,
.proj-cta__btn,
.psingle-cta__btn,
.psingle-cta__btn--ghost,
.psingle-cta__btn--dark,
.section-head__action,
.svc-enquiry__submit,
.footer-newsletter button[type="submit"] {
	background: #ffffff !important;
	color: #000000 !important;
	border: none !important;
	box-shadow: 0 6px 18px -6px rgba(20,15,12,.25) !important;
}
.btn:not(.btn-whatsapp):hover,
.btn-primary:hover,
.btn-secondary:hover,
.btn-outline:hover,
.btn-link:hover,
.btn-banner:hover,
.home-about__btn:hover,
.proj-cta__btn:hover,
.psingle-cta__btn:hover,
.psingle-cta__btn--ghost:hover,
.psingle-cta__btn--dark:hover,
.section-head__action:hover,
.svc-enquiry__submit:hover,
.footer-newsletter button[type="submit"]:hover {
	background: #2a201a !important;
	color: #fff !important;
	border: none !important;
	box-shadow: 0 10px 26px -8px rgba(20,15,12,.4) !important;
}

/* =========================================================
   Collections — horizontal slider (3 per view, scroll for more)
   ========================================================= */
.collections-slider { position: relative; }
.collections-slider .projects-viewport {
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding: 4px 0;
}
.collections-slider .projects-viewport::-webkit-scrollbar { display: none; }
.collections-slider .collections-track {
	display: flex;
	gap: 36px;
	padding: 0;
}
.collections-slider .coll-slide {
	flex: 0 0 calc((100% - 72px) / 3); /* 3 cards + 2 gaps of 36px */
	min-width: 0;
	scroll-snap-align: start;
}
@media (max-width: 980px) {
	.collections-slider .collections-track { gap: 24px; }
	.collections-slider .coll-slide { flex: 0 0 calc((100% - 24px) / 2); }
}
@media (max-width: 600px) {
	.collections-slider .coll-slide { flex: 0 0 88%; }
}
/* When 3 or fewer cards, behave like a static row (no scroll snap needed) */
.collections-slider.is-static .projects-viewport { overflow: visible; scroll-snap-type: none; }
@media (max-width: 600px) {
	.collections-slider.is-static .coll-slide { flex: 0 0 88%; }
}
/* Arrow positions inside the section padding */
.collections-slider .collections-prev { left: 8px; }
.collections-slider .collections-next { right: 8px; }

/* Dots — hidden on desktop, shown on mobile */
.collections-dots { display: none; }
.collections-dot {
	width: 8px; height: 8px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: rgba(42,32,26,.25);
	cursor: pointer;
	transition: background .25s ease, transform .25s ease;
}
.collections-dot.is-active { background: var(--ak-accent); transform: scale(1.25); }

/* Mobile: hide arrows, show dots */
@media (max-width: 768px) {
	.collections-slider .collections-prev,
	.collections-slider .collections-next { display: none; }
	.collections-dots {
		display: flex;
		justify-content: center;
		gap: 9px;
		margin-top: 22px;
	}
}

/* =========================================================
   Single project/service — click main image to open full-screen
   ========================================================= */
.ak-img-lightbox {
	position: fixed; inset: 0; z-index: 9999;
	display: flex; align-items: center; justify-content: center;
	background: rgba(20,15,12,.92);
	backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
	opacity: 0; visibility: hidden;
	transition: opacity .35s ease, visibility 0s linear .35s;
	padding: 4vh 4vw;
	cursor: zoom-out;
}
.ak-img-lightbox.is-open { opacity: 1; visibility: visible; transition: opacity .35s ease; }
.ak-img-lightbox img {
	max-width: 100%; max-height: 92vh;
	width: auto; height: auto;
	object-fit: contain;
	display: block;
	box-shadow: 0 30px 80px -20px rgba(0,0,0,.6);
	transform: scale(.97);
	transition: transform .4s cubic-bezier(.22,.61,.36,1);
}
.ak-img-lightbox.is-open img { transform: scale(1); }
.ak-img-lightbox__close {
	position: absolute; top: 22px; right: 24px;
	width: 46px; height: 46px;
	display: flex; align-items: center; justify-content: center;
	background: transparent; border: 1px solid rgba(255,255,255,.35);
	color: #fff; border-radius: 50%; cursor: pointer;
	transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.ak-img-lightbox__close:hover { background: rgba(255,255,255,.12); border-color: #fff; transform: rotate(90deg); }

/* Full-screen lightbox prev/next arrows */
.ak-img-lightbox__nav {
	position: absolute; top: 50%; transform: translateY(-50%);
	width: 54px; height: 54px;
	display: flex; align-items: center; justify-content: center;
	background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.35);
	color: #fff; border-radius: 50%; cursor: pointer; z-index: 2;
	transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.ak-img-lightbox__nav:hover { background: rgba(255,255,255,.16); border-color: #fff; }
.ak-img-lightbox__prev { left: 24px; }
.ak-img-lightbox__next { right: 24px; }
.ak-img-lightbox__prev:hover { transform: translateY(-50%) translateX(-3px); }
.ak-img-lightbox__next:hover { transform: translateY(-50%) translateX(3px); }
.ak-img-lightbox img.is-swapping { opacity: 0; }
.ak-img-lightbox img { transition: transform .4s cubic-bezier(.22,.61,.36,1), opacity .25s ease; }
@media (max-width: 600px) {
	.ak-img-lightbox__nav { width: 44px; height: 44px; }
	.ak-img-lightbox__prev { left: 10px; }
	.ak-img-lightbox__next { right: 10px; }
}
