/*
Theme Name: Codelectric
Theme URI: https://codelectric.com
Author: Codelectric
Author URI: https://codelectric.com
Description: Moderna, premium portfolio tema za tvrtku za razvoj softvera.
Version: 1.4.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: codelectric
Tags: portfolio, one-page, custom-menu, featured-images, full-width-template
*/

/* ========================================================================
   CSS Variables
   ======================================================================== */

:root {
	--color-primary: #345e7d;
	--color-primary-dark: #2b4257;
	--color-secondary: #88a9c3;
	--color-accent: #6da7cc;
	--color-bg-light: #e3ebf2;
	--color-bg-white: #ffffff;
	--color-text: #2b4257;
	--color-text-light: #5a7a94;
	--color-text-muted: #88a9c3;
	--color-border: #d0dce6;
	--color-white: #ffffff;

	--font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-display: 'Space Grotesk', 'Inter', sans-serif;

	--container-max: 1200px;
	--container-narrow: 800px;
	--header-height: 80px;
	--section-spacing: 120px;
	--spacing-page-top: calc(var(--section-spacing) + var(--header-height));
	--content-padding: 32px;
	--border-radius: 16px;
	--border-radius-sm: 10px;
	--transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-fast: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	--transition-slow: 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ========================================================================
   Reset & Base
   ======================================================================== */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html,
body {
	overflow-x: hidden;
}

html {
	scroll-behavior: smooth;
	scroll-padding-top: 64px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body {
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.7;
	color: var(--color-text);
	background-color: var(--color-bg-white);
}

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

a {
	color: var(--color-accent);
	text-decoration: none;
	transition: color var(--transition);
}

a:hover {
	color: var(--color-primary);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	color: var(--color-primary-dark);
	line-height: 1.2;
	font-weight: 600;
}

::selection {
	background: var(--color-accent);
	color: var(--color-white);
}

/* ========================================================================
   Utility
   ======================================================================== */

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--content-padding);
}

.container--text-center {
	text-align: center;
}

.container--narrow {
	max-width: var(--container-narrow);
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ========================================================================
   Section Common
   ======================================================================== */

.section {
	padding: var(--section-spacing) 0;
}

.section--page-top {
	padding-top: var(--spacing-page-top);
}

.section--alt {
	background-color: var(--color-bg-light);
}

.section--dark {
	background-color: var(--color-primary-dark);
	color: var(--color-bg-light);
}

.section--dark h2,
.section--dark h3,
.section--dark h4 {
	color: var(--color-white);
}

.section--dark p {
	color: var(--color-secondary);
}

.section__label {
	display: inline-block;
	font-family: var(--font-display);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: 16px;
}

.section__title {
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: 20px;
}

.section__subtitle {
	font-size: 1.125rem;
	color: var(--color-text-light);
	max-width: 600px;
	line-height: 1.7;
}

.section__subtitle--spaced {
	margin-bottom: 48px;
}

.section__header {
	margin-bottom: 64px;
}

.section__header--center {
	text-align: center;
}

.section__header--center .section__subtitle {
	margin-left: auto;
	margin-right: auto;
}

.section__subtitle--cta {
	margin: 0 auto 32px;
}

.section--no-top {
	padding-top: 0;
}

.project-tech__tags--center {
	justify-content: center;
}

.section__empty {
	text-align: center;
	color: var(--color-text-light);
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}

.section__footer {
	text-align: center;
	margin-top: 36px;
}

/* ========================================================================
   Buttons
   ======================================================================== */

.btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-display);
	font-size: 15px;
	font-weight: 600;
	padding: 14px 32px;
	border-radius: 50px;
	border: 2px solid transparent;
	cursor: pointer;
	transition: all var(--transition);
	text-decoration: none;
	line-height: 1.4;
	position: relative;
	overflow: hidden;
}

.btn::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	opacity: 0;
	transition: opacity var(--transition-fast);
	background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 100%);
}

.btn:active::after {
	opacity: 1;
}

.btn:active {
	transform: translateY(0) scale(0.98);
}

.btn--primary {
	background-color: var(--color-accent);
	color: var(--color-white);
	border-color: var(--color-accent);
}

.btn--primary:hover {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
	transform: translateY(-2px);
	box-shadow: 0 8px 32px rgba(52, 94, 125, 0.3);
}

.btn--outline {
	background-color: transparent;
	color: var(--color-white);
	border-color: rgba(255, 255, 255, 0.3);
}

.btn--outline:hover {
	background-color: var(--color-white);
	color: var(--color-primary-dark);
	border-color: var(--color-white);
	transform: translateY(-2px);
	box-shadow: 0 8px 32px rgba(255, 255, 255, 0.15);
}

.btn--outline-dark {
	background-color: transparent;
	color: var(--color-primary);
	border-color: var(--color-border);
}

.btn--outline-dark:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
	transform: translateY(-2px);
	box-shadow: 0 8px 32px rgba(52, 94, 125, 0.2);
}

.btn--sm {
	padding: 10px 24px;
	font-size: 13px;
}

.btn:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 3px;
}

/* ========================================================================
   Header / Navigation
   ======================================================================== */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(24px);
	-webkit-backdrop-filter: blur(24px);
	border-bottom: 1px solid rgba(208, 220, 230, 0.4);
	border-radius: 0 0 20px 20px;
	transition: all var(--transition);
}

.site-header--scrolled {
	background: rgba(255, 255, 255, 0.97);
	border-bottom-color: rgba(208, 220, 230, 0.7);
	box-shadow: 0 1px 24px rgba(43, 66, 87, 0.06);
}

.site-header--scrolled .container {
	height: 64px;
}

.site-header--scrolled .site-logo {
	height: 30px;
}

.site-header .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--header-height);
	transition: height var(--transition);
	min-width: 0;
}

.site-logo-link {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
}

.site-logo {
	height: 36px;
	width: auto;
	transition: height var(--transition);
}

.site-name {
	font-family: var(--font-display);
	font-size: 20px;
	font-weight: 700;
	color: var(--color-primary-dark);
	letter-spacing: -0.02em;
}

.main-navigation {
	display: flex;
	align-items: center;
	min-width: 0;
}

.nav-menu {
	display: flex;
	list-style: none;
	gap: 4px;
	margin: 0;
	padding: 0;
}

.nav-menu li a {
	display: block;
	padding: 8px 18px;
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 500;
	color: var(--color-text-light);
	border-radius: 50px;
	transition: all var(--transition);
	text-decoration: none;
}

.nav-menu li a:hover,
.nav-menu li.current-menu-item a,
.nav-menu li.current_page_item a {
	color: var(--color-primary-dark);
	background-color: var(--color-bg-light);
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-shrink: 0;
}

.header-cta {
	margin-left: 12px;
}

.header-cta .btn {
	padding: 10px 24px;
	font-size: 14px;
	white-space: nowrap;
}

/* ========================================================================
   Mobile Menu Toggle
   ======================================================================== */

.mobile-menu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	cursor: pointer;
	width: 44px;
	height: 44px;
	padding: 0;
	color: var(--color-primary-dark);
	border-radius: var(--border-radius-sm);
	transition: background var(--transition), color var(--transition);
	position: relative;
}

.mobile-menu-toggle:hover {
	background: var(--color-bg-light);
}

.mobile-menu-toggle:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

.mobile-menu-toggle svg {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: opacity var(--transition-fast), transform var(--transition-fast);
}

.mobile-menu-toggle .icon-close {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(-90deg) scale(0.6);
}

.mobile-menu-toggle.is-active .icon-menu {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg) scale(0.6);
}

.mobile-menu-toggle.is-active .icon-close {
	opacity: 1;
	transform: translate(-50%, -50%) rotate(0) scale(1);
}

/* ========================================================================
   Mobile Navigation
   ======================================================================== */

.mobile-nav {
	overflow: hidden;
	max-height: 0;
	opacity: 0;
	background: var(--color-bg-white);
	border-top: 1px solid transparent;
	border-radius: 0 0 20px 20px;
	padding: 0 var(--content-padding);
	transition:
		max-height 0.45s cubic-bezier(0.16, 1, 0.3, 1),
		opacity 0.35s ease,
		padding 0.45s cubic-bezier(0.16, 1, 0.3, 1),
		border-color 0.3s ease;
}

.mobile-nav.is-open {
	max-height: 400px;
	opacity: 1;
	padding: 16px var(--content-padding) 28px;
	border-top-color: var(--color-border);
}

.mobile-nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.mobile-nav a,
.mobile-nav ul li a {
	display: block;
	padding: 14px 0;
	font-family: var(--font-display);
	font-size: 16px;
	font-weight: 500;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-bg-light);
	text-decoration: none;
	transition: color var(--transition), padding-left var(--transition);
	transform: translateY(8px);
	opacity: 0;
}

.mobile-nav.is-open a,
.mobile-nav.is-open ul li a {
	transform: translateY(0);
	opacity: 1;
}

.mobile-nav a:nth-child(1), .mobile-nav ul li:nth-child(1) a { transition-delay: 0.05s; }
.mobile-nav a:nth-child(2), .mobile-nav ul li:nth-child(2) a { transition-delay: 0.1s; }
.mobile-nav a:nth-child(3), .mobile-nav ul li:nth-child(3) a { transition-delay: 0.15s; }
.mobile-nav a:nth-child(4), .mobile-nav ul li:nth-child(4) a { transition-delay: 0.2s; }
.mobile-nav a:nth-child(5), .mobile-nav ul li:nth-child(5) a { transition-delay: 0.25s; }
.mobile-nav a:nth-child(6), .mobile-nav ul li:nth-child(6) a { transition-delay: 0.3s; }
.mobile-nav a:nth-child(7), .mobile-nav ul li:nth-child(7) a { transition-delay: 0.35s; }

.mobile-nav a:last-child,
.mobile-nav ul li:last-child a {
	border-bottom: none;
}

.mobile-nav a:hover,
.mobile-nav ul li a:hover {
	color: var(--color-accent);
	padding-left: 8px;
}

.mobile-nav .mobile-nav-cta {
	display: block;
	margin-top: 16px;
	text-align: center;
}

/* ========================================================================
   Hero
   ======================================================================== */

.hero {
	min-height: 100vh;
	display: flex;
	align-items: center;
	background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 50%, var(--color-accent) 100%);
	position: relative;
	overflow: hidden;
	padding-top: var(--header-height);
}

.hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 20% 50%, rgba(109, 167, 204, 0.15) 0%, transparent 50%),
		radial-gradient(circle at 80% 20%, rgba(136, 169, 195, 0.1) 0%, transparent 40%),
		radial-gradient(circle at 60% 80%, rgba(255, 255, 255, 0.05) 0%, transparent 40%);
	pointer-events: none;
}

.hero__grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-size: 60px 60px;
	pointer-events: none;
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: rgba(43, 66, 87, 0.65);
	pointer-events: none;
	z-index: 0;
}

.hero .container {
	position: relative;
	z-index: 1;
	padding-top: 20px;
	padding-bottom: 40px;
}

.hero__content {
	max-width: 720px;
}

.hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.15);
	padding: 8px 18px;
	border-radius: 50px;
	font-size: 14px;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 32px;
	backdrop-filter: blur(10px);
}

.hero__badge-dot {
	width: 8px;
	height: 8px;
	background: #4ade80;
	border-radius: 50%;
	animation: pulse 2s infinite;
}

@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.4; }
}

.hero__title {
	font-size: clamp(2.5rem, 6vw, 4.25rem);
	font-weight: 700;
	color: var(--color-white);
	line-height: 1.1;
	letter-spacing: -0.03em;
	margin-bottom: 24px;
}

.hero__title-accent {
	background: linear-gradient(135deg, #e3ebf2 0%, var(--color-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.hero__description {
	font-size: 1.2rem;
	color: rgba(255, 255, 255, 0.7);
	max-width: 540px;
	line-height: 1.7;
	margin-bottom: 40px;
}

.hero__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.hero__stats {
	display: flex;
	justify-content: space-between;
	text-align: center;
	margin-top: 80px;
	padding-top: 40px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.hero__stat {
	flex: 1;
	min-width: 0;
}

.hero__stat-number {
	font-family: var(--font-display);
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-white);
	line-height: 1;
	margin-bottom: 4px;
}

.hero__stat-label {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.5);
	font-weight: 500;
}

/* ========================================================================
   Services
   ======================================================================== */

.services-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.service-card {
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: 40px var(--content-padding);
	transition: all var(--transition);
	position: relative;
	overflow: hidden;
}

.service-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-primary));
	opacity: 0;
	transition: opacity var(--transition);
}

.service-card:hover {
	border-color: var(--color-accent);
	transform: translateY(-6px);
	box-shadow: 0 24px 64px rgba(43, 66, 87, 0.1);
}

.service-card:hover::before {
	opacity: 1;
}

.service-card__icon {
	width: 52px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-bg-light);
	border-radius: var(--border-radius-sm);
	margin-bottom: 24px;
	color: var(--color-accent);
	transition: background var(--transition), color var(--transition);
}

.service-card:hover .service-card__icon {
	background: var(--color-accent);
	color: var(--color-white);
}

.service-card__icon svg {
	width: 24px;
	height: 24px;
}

.service-card__image {
	width: 100%;
	aspect-ratio: 1;
	border-radius: var(--border-radius-sm);
	overflow: hidden;
	margin-bottom: 24px;
	background: var(--color-bg-light);
}

.service-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.service-card__title {
	font-size: 1.2rem;
	margin-bottom: 12px;
	font-weight: 600;
}

.service-card__text {
	font-size: 0.95rem;
	color: var(--color-text-light);
	line-height: 1.7;
}

/* ========================================================================
   Portfolio / Projects
   ======================================================================== */

.portfolio-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--content-padding);
}

.portfolio-card {
	background: var(--color-bg-white);
	border-radius: var(--border-radius);
	overflow: hidden;
	border: 1px solid var(--color-border);
	transition: all var(--transition);
}

.portfolio-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 32px 72px rgba(43, 66, 87, 0.12);
	border-color: transparent;
}

.portfolio-card__image {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	position: relative;
}

.portfolio-card__image-inner {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
	font-weight: 700;
	font-family: var(--font-display);
	color: var(--color-white);
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.portfolio-card:hover .portfolio-card__image-inner {
	transform: scale(1.05);
}

.portfolio-card__image-inner img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

a.portfolio-card__image {
	display: block;
	text-decoration: none;
}

.portfolio-card__body {
	padding: 28px var(--content-padding) var(--content-padding);
}

.portfolio-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 16px;
}

.portfolio-card__tag {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	color: var(--color-accent);
	background: var(--color-bg-light);
	padding: 4px 12px;
	border-radius: 50px;
	letter-spacing: 0.02em;
	text-decoration: none;
	transition: background var(--transition), color var(--transition), transform var(--transition-fast);
}

a.portfolio-card__tag:hover {
	background: var(--color-accent);
	color: var(--color-white);
	transform: translateY(-1px);
}

.portfolio-card__tag--current {
	background: var(--color-accent);
	color: var(--color-white);
}

.portfolio-card__title {
	font-size: 1.3rem;
	margin-bottom: 10px;
	font-weight: 600;
}

.portfolio-card__title a {
	color: var(--color-primary-dark);
	text-decoration: none;
	transition: color var(--transition);
}

.portfolio-card__title a:hover {
	color: var(--color-accent);
}

.portfolio-card__desc {
	font-size: 0.95rem;
	color: var(--color-text-light);
	line-height: 1.7;
}

.portfolio-card__meta {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--color-bg-light);
}

.portfolio-card__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 13px;
	color: var(--color-text-muted);
}

.portfolio-card__meta-item svg {
	flex-shrink: 0;
	color: var(--color-accent);
}

/* ========================================================================
   Skills / Tech Stack
   ======================================================================== */

.skills-content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: start;
}

.skills-text .section__subtitle {
	margin-bottom: 32px;
}

.skill-categories {
	display: grid;
	gap: 32px;
}

.skill-category__title {
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted);
	margin-bottom: 16px;
}

.skill-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.skill-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 20px;
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	border-radius: 50px;
	font-size: 14px;
	font-weight: 500;
	color: var(--color-text);
	transition: all var(--transition);
}

.skill-tag:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(109, 167, 204, 0.15);
}

.skill-tag svg {
	width: 16px;
	height: 16px;
	opacity: 0.6;
}

.approach-list {
	list-style: none;
	padding: 0;
	display: grid;
	gap: 24px;
}

.approach-list li {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.approach-list__icon {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-bg-light);
	border-radius: 50%;
	color: var(--color-accent);
	margin-top: 2px;
	transition: background var(--transition), color var(--transition);
}

.approach-list li:hover .approach-list__icon {
	background: var(--color-accent);
	color: var(--color-white);
}

.approach-list__icon svg {
	width: 16px;
	height: 16px;
}

.approach-list__title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-primary-dark);
	margin-bottom: 4px;
}

.approach-list__text {
	font-size: 0.9rem;
	color: var(--color-text-light);
	line-height: 1.6;
}

/* ========================================================================
   Contact
   ======================================================================== */

.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: start;
}

.contact-info {
	display: grid;
	gap: 32px;
}

.contact-method {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	transition: transform var(--transition-fast);
}

.contact-method:hover {
	transform: translateX(4px);
}

.contact-method__icon {
	width: 52px;
	height: 52px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(109, 167, 204, 0.15);
	border-radius: var(--border-radius-sm);
	color: var(--color-accent);
	transition: background var(--transition);
}

.contact-method:hover .contact-method__icon {
	background: rgba(109, 167, 204, 0.25);
}

.contact-method__icon svg {
	width: 22px;
	height: 22px;
}

.contact-method__label {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted);
	margin-bottom: 4px;
}

.contact-method__value {
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--color-white);
}

.contact-method__value a {
	color: var(--color-white);
}

.contact-method__value a:hover {
	color: var(--color-accent);
}

.contact-social {
	margin-top: 8px;
}

.contact-social__links {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: 8px;
}

.contact-social__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--border-radius-sm);
	background: rgba(255, 255, 255, 0.1);
	color: var(--color-white);
	transition: background 0.2s, color 0.2s;
}

.contact-social__link:hover {
	background: var(--color-accent);
	color: var(--color-white);
}

.contact-form {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--border-radius);
	padding: 40px;
	backdrop-filter: blur(10px);
}

.contact-form .form-group {
	margin-bottom: 20px;
}

.contact-form .form-group--hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.contact-form label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--color-secondary);
	margin-bottom: 8px;
}

.contact-form input,
.contact-form textarea {
	width: 100%;
	padding: 14px 18px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: var(--border-radius-sm);
	color: var(--color-white);
	font-family: var(--font-body);
	font-size: 15px;
	transition: border-color var(--transition), box-shadow var(--transition);
	outline: none;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
	color: rgba(255, 255, 255, 0.3);
}

.contact-form input:focus,
.contact-form textarea:focus {
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(109, 167, 204, 0.15);
}

.contact-form textarea {
	resize: vertical;
	min-height: 120px;
}

.contact-form .btn {
	width: 100%;
	justify-content: center;
	margin-top: 4px;
}

.contact-form__message {
	margin-bottom: 20px;
	padding: 14px 18px;
	border-radius: var(--border-radius-sm);
	font-weight: 500;
}

.contact-form__message--success {
	background: rgba(76, 175, 80, 0.2);
	border: 1px solid rgba(76, 175, 80, 0.4);
	color: #a5d6a7;
}

.contact-form__message--error {
	background: rgba(244, 67, 54, 0.2);
	border: 1px solid rgba(244, 67, 54, 0.4);
	color: #ef9a9a;
}

/* ========================================================================
   Footer
   ======================================================================== */

.site-footer {
	background-color: var(--color-primary-dark);
	color: var(--color-secondary);
	padding: 48px 0;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.footer-top {
	padding: 64px 0 40px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.footer-top__grid {
	display: flex;
	justify-content: space-between;
	align-items: start;
	gap: 48px;
	flex-wrap: wrap;
}

.footer-brand {
	max-width: 280px;
}

.footer-brand .site-logo {
	height: 32px;
	margin-bottom: 16px;
	filter: brightness(0) invert(1);
}

.footer-brand__text {
	font-size: 14px;
	color: var(--color-text-muted);
	line-height: 1.7;
	margin-bottom: 20px;
}

.footer-social {
	display: flex;
	gap: 12px;
}

.footer-social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	color: var(--color-text-muted);
	transition: all var(--transition);
}

.footer-social a:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: var(--color-white);
	transform: translateY(-2px);
}

.footer-social svg {
	width: 16px;
	height: 16px;
}

.footer-col__title {
	font-family: var(--font-display);
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-white);
	margin-bottom: 20px;
}

.footer-col__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-col__list li {
	margin-bottom: 10px;
}

.footer-col__list a {
	font-size: 14px;
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--transition), padding-left var(--transition);
}

.footer-col__list a:hover {
	color: var(--color-white);
	padding-left: 4px;
}

.footer-bottom {
	padding: 24px 0;
}

.footer-bottom__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}

.footer-nav__list {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-nav__list a {
	font-size: 13px;
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--transition);
}

.footer-nav__list a:hover {
	color: var(--color-white);
}

.footer-bottom__copy {
	font-size: 13px;
	color: var(--color-text-muted);
}

.footer-bottom__links {
	display: flex;
	gap: 24px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-bottom__links a {
	font-size: 13px;
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--transition);
}

.footer-bottom__links a:hover {
	color: var(--color-white);
}

/* Legacy footer structures */
.footer-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}

.footer-copy {
	font-size: 14px;
	color: var(--color-text-muted);
}

.footer-links {
	display: flex;
	gap: 24px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-links a {
	font-size: 14px;
	color: var(--color-text-muted);
	transition: color var(--transition);
	text-decoration: none;
}

.footer-links a:hover {
	color: var(--color-white);
}

.footer-widgets {
	padding: 64px 0 32px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	margin-bottom: 32px;
}

.footer-widgets__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
}

.footer-widgets__col .widget-title {
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-white);
	margin-bottom: 16px;
}

.footer-widgets__col .widget {
	color: var(--color-text-muted);
	font-size: 14px;
	line-height: 1.8;
}

.footer-widgets__col .widget a {
	color: var(--color-text-muted);
	transition: color var(--transition);
}

.footer-widgets__col .widget a:hover {
	color: var(--color-white);
}

.footer-widgets__col .widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-widgets__col .widget ul li {
	margin-bottom: 8px;
}

/* ========================================================================
   Page / Default Templates
   ======================================================================== */

.page-content {
	padding: var(--section-spacing) 0;
	min-height: 60vh;
}

.page-content.page-content--top {
	padding-top: var(--spacing-page-top);
}

.page-content h1 {
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: 24px;
}

.page-content p {
	max-width: 720px;
	margin-bottom: 16px;
}

/* Cookie consent banner */
.cookie-banner {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 50000;
	padding: 16px 0;
	background: var(--color-bg-white);
	border-top: 1px solid var(--color-border);
	box-shadow: 0 -8px 32px rgba(43, 66, 87, 0.08);
}

.cookie-banner__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
}

.cookie-banner__text {
	flex: 1 1 280px;
	min-width: 0;
}

.cookie-banner__message {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--color-text);
	max-width: none;
}

.cookie-banner__link {
	color: var(--color-accent);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 3px;
	margin-left: 4px;
	white-space: nowrap;
}

.cookie-banner__link:hover {
	color: var(--color-primary);
}

.cookie-banner__actions {
	flex-shrink: 0;
}

/* Legal / privacy page prose */
.legal-page {
	padding: var(--spacing-page-top) 0 var(--section-spacing);
	min-height: 60vh;
}

.legal-page .legal-page__intro {
	max-width: var(--container-narrow);
	margin-bottom: 40px;
}

.legal-page .legal-page__intro p {
	max-width: none;
}

.legal-page__section {
	max-width: var(--container-narrow);
	margin-bottom: 40px;
}

.legal-page__section h2 {
	font-family: var(--font-display);
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin: 0 0 16px;
	letter-spacing: -0.02em;
}

.legal-page__section p,
.legal-page__section li {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--color-text);
	margin-bottom: 12px;
}

.legal-page__section ul {
	margin: 0 0 16px;
	padding-left: 1.25em;
}

.legal-page__section li {
	margin-bottom: 8px;
}

.single-project__tags {
	margin-bottom: 16px;
}

/* ========================================================================
   Project Hero & Detail Sections
   ======================================================================== */

.project-hero {
	padding-bottom: 48px;
}

.project-hero__inner {
	max-width: var(--container-narrow);
}

.project-hero__title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
	margin-bottom: 20px;
}

.project-hero__desc {
	font-size: 1.15rem;
	color: var(--color-text-light);
	line-height: 1.7;
	max-width: 640px;
	margin-bottom: 32px;
}

.project-info-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 32px;
	padding: 24px 0;
	border-top: 1px solid var(--color-border);
}

.project-info-bar__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.project-info-bar__item > svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	color: var(--color-accent);
	margin-top: 2px;
}

.project-info-bar__label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted);
	margin-bottom: 2px;
}

.project-info-bar__value {
	display: block;
	font-size: 15px;
	font-weight: 600;
	color: var(--color-primary-dark);
}

.project-info-bar__link {
	color: var(--color-accent) !important;
	text-decoration: none;
	word-break: break-all;
}

.project-info-bar__link:hover {
	text-decoration: underline;
}

.project-featured {
	border-radius: var(--border-radius);
	overflow: hidden;
	margin-bottom: 0;
}

.project-featured img {
	width: 100%;
	height: auto;
	display: block;
}

.project-impact__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 24px;
}

.project-impact__card {
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: 36px var(--content-padding);
	text-align: center;
	transition: all var(--transition);
	position: relative;
	overflow: hidden;
}

.project-impact__card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-primary));
	transform: scaleX(0);
	transition: transform var(--transition);
}

.project-impact__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 48px rgba(43, 66, 87, 0.08);
	border-color: var(--color-accent);
}

.project-impact__card:hover::before {
	transform: scaleX(1);
}

.project-impact__num {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 700;
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: 8px;
}

.project-impact__lbl {
	font-size: 0.95rem;
	color: var(--color-text-light);
	font-weight: 500;
}

.project-tech__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
}

/* ========================================================================
   404
   ======================================================================== */

.error-404 {
	min-height: 80vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding-top: var(--header-height);
}

.error-404__code {
	font-family: var(--font-display);
	font-size: clamp(6rem, 15vw, 12rem);
	font-weight: 800;
	background: linear-gradient(135deg, var(--color-bg-light) 0%, var(--color-border) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1;
	margin-bottom: 16px;
}

.error-404 h1 {
	font-size: 1.8rem;
	margin-bottom: 16px;
}

.error-404 p {
	color: var(--color-text-light);
	margin-bottom: 32px;
}

/* ========================================================================
   Entry Content (single pages / projects)
   ======================================================================== */

.entry-content {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--color-text);
}

.entry-content h2 {
	font-size: 1.6rem;
	margin-top: 40px;
	margin-bottom: 16px;
}

.entry-content h3 {
	font-size: 1.3rem;
	margin-top: 32px;
	margin-bottom: 12px;
}

.entry-content p {
	margin-bottom: 20px;
	max-width: 720px;
}

.entry-content ul,
.entry-content ol {
	margin-bottom: 20px;
	padding-left: 24px;
}

.entry-content li {
	margin-bottom: 8px;
}

.entry-content img {
	border-radius: var(--border-radius);
	margin: 24px 0;
}

.entry-content a {
	color: var(--color-accent);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.entry-content a:hover {
	color: var(--color-primary);
}

.entry-content blockquote {
	border-left: 3px solid var(--color-accent);
	padding: 16px 24px;
	margin: 24px 0;
	background: var(--color-bg-light);
	border-radius: 0 var(--border-radius-sm) var(--border-radius-sm) 0;
	font-style: italic;
	color: var(--color-text-light);
}

.section--dark .entry-content,
.section--dark .entry-content p {
	color: var(--color-secondary);
}

.section--dark .entry-content a {
	color: var(--color-accent);
}

/* ========================================================================
   Blog Section
   ======================================================================== */

.blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

.blog-card {
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	overflow: hidden;
	transition: all var(--transition);
	display: flex;
	flex-direction: column;
}

.blog-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 24px 64px rgba(43, 66, 87, 0.1);
	border-color: transparent;
}

.blog-card__image {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	position: relative;
	background: var(--color-bg-light);
}

.blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.blog-card:hover .blog-card__image img {
	transform: scale(1.05);
}

.blog-card__image-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--color-bg-light), var(--color-border));
	color: var(--color-text-muted);
}

.blog-card__body {
	padding: 24px var(--content-padding) var(--content-padding);
	display: flex;
	flex-direction: column;
	flex: 1;
}

.blog-card__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 13px;
	color: var(--color-text-muted);
	margin-bottom: 12px;
}

.blog-card__meta svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

.blog-card__category {
	font-size: 12px;
	font-weight: 600;
	color: var(--color-accent);
	background: var(--color-bg-light);
	padding: 3px 10px;
	border-radius: 50px;
	text-decoration: none;
	transition: background var(--transition), color var(--transition);
}

.blog-card__category:hover {
	background: var(--color-accent);
	color: var(--color-white);
}

.blog-card__title {
	font-size: 1.15rem;
	font-weight: 600;
	margin-bottom: 10px;
	line-height: 1.35;
}

.blog-card__title a {
	color: var(--color-primary-dark);
	text-decoration: none;
	transition: color var(--transition);
}

.blog-card__title a:hover {
	color: var(--color-accent);
}

.blog-card__excerpt {
	font-size: 0.9rem;
	color: var(--color-text-light);
	line-height: 1.65;
	flex: 1;
}

.blog-card__read-more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 600;
	color: var(--color-accent);
	margin-top: 16px;
	text-decoration: none;
	transition: gap var(--transition), color var(--transition);
}

.blog-card__read-more:hover {
	color: var(--color-primary);
	gap: 10px;
}

.blog-card__read-more svg {
	width: 16px;
	height: 16px;
	transition: transform var(--transition);
}

.blog-card__read-more:hover svg {
	transform: translateX(2px);
}

/* ========================================================================
   Single Blog Post
   ======================================================================== */

.single-post__header {
	margin-bottom: 40px;
}

.single-post__meta {
	font-size: 14px;
	color: var(--color-text-muted);
	margin-bottom: 16px;
}

.single-post__featured {
	margin-bottom: 40px;
	border-radius: var(--border-radius);
	overflow: hidden;
}

.single-post__featured img {
	width: 100%;
	height: auto;
}

.single-post__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 40px;
}

.single-post__nav {
	display: flex;
	justify-content: space-between;
	gap: 24px;
	margin-top: 48px;
	padding-top: 24px;
	border-top: 1px solid var(--color-border);
}

.single-post__nav-link {
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 600;
	color: var(--color-text-light);
	text-decoration: none;
	transition: color var(--transition);
}

.single-post__nav-link:hover {
	color: var(--color-accent);
}

/* ========================================================================
   Pagination
   ======================================================================== */

.pagination {
	display: flex;
	justify-content: center;
	gap: 8px;
	flex-wrap: wrap;
	margin-top: 48px;
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 14px;
	border-radius: 50px;
	font-size: 14px;
	font-weight: 500;
	color: var(--color-text-light);
	background: var(--color-bg-white);
	border: 1px solid var(--color-border);
	transition: all var(--transition);
	text-decoration: none;
}

.pagination .page-numbers:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
	transform: translateY(-2px);
}

.pagination .page-numbers.current {
	background: var(--color-accent);
	color: var(--color-white);
	border-color: var(--color-accent);
}

/* ========================================================================
   Animations — Scroll Reveal System
   ======================================================================== */

.fade-up {
	opacity: 0;
	transform: translateY(40px);
	transition:
		opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
	transition-delay: var(--stagger, 0s);
}

.fade-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.fade-left {
	opacity: 0;
	transform: translateX(-40px);
	transition:
		opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
	transition-delay: var(--stagger, 0s);
}

.fade-left.is-visible {
	opacity: 1;
	transform: translateX(0);
}

.fade-right {
	opacity: 0;
	transform: translateX(40px);
	transition:
		opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
	transition-delay: var(--stagger, 0s);
}

.fade-right.is-visible {
	opacity: 1;
	transform: translateX(0);
}

.scale-in {
	opacity: 0;
	transform: scale(0.92);
	transition:
		opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
	transition-delay: var(--stagger, 0s);
}

.scale-in.is-visible {
	opacity: 1;
	transform: scale(1);
}

.blur-in {
	opacity: 0;
	filter: blur(8px);
	transform: translateY(16px);
	transition:
		opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
		filter 0.8s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
	transition-delay: var(--stagger, 0s);
}

.blur-in.is-visible {
	opacity: 1;
	filter: blur(0);
	transform: translateY(0);
}

/* ========================================================================
   Reduced Motion
   ======================================================================== */

@media (prefers-reduced-motion: reduce) {
	.fade-up,
	.fade-left,
	.fade-right,
	.scale-in,
	.blur-in {
		opacity: 1;
		transform: none;
		filter: none;
		transition: none;
	}

	html {
		scroll-behavior: auto;
	}

	.mobile-nav {
		transition: none;
	}

	.mobile-nav a,
	.mobile-nav ul li a {
		transition: none;
		transform: none;
		opacity: 1;
	}
}

/* ========================================================================
   Responsive — Tablet (1024px)
   ======================================================================== */

@media (max-width: 1024px) {
	:root {
		--section-spacing: 80px;
		--content-padding: 28px;
	}

	.header-cta {
		display: none;
	}

	.mobile-menu-toggle {
		display: flex;
	}

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

	.skills-content {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.hero__stats {
		margin-top: 48px;
	}

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

/* ========================================================================
   Responsive — Mobile (768px)
   ======================================================================== */

@media (max-width: 768px) {
	:root {
		--section-spacing: 56px;
		--header-height: 64px;
		--content-padding: 24px;
	}

	html {
		scroll-padding-top: 56px;
	}

	.site-header {
		border-radius: 0 0 16px 16px;
	}

	.site-header .container {
		height: var(--header-height);
	}

	.site-header--scrolled .container {
		height: 56px;
	}

	.main-navigation {
		display: none;
	}

	.services-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.portfolio-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	.contact-grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.hero {
		align-items: flex-start;
		min-height: auto;
	}

	.hero .container {
		padding-top: 10px;
		padding-bottom: 32px;
	}

	.hero__title {
		font-size: clamp(2rem, 8vw, 3rem);
	}

	.hero__description {
		margin-bottom: 28px;
	}

	.hero__stats {
		margin-top: 40px;
		padding-top: 28px;
	}

	.hero__stat-number {
		font-size: 1.75rem;
	}

	.hero__stat-label {
		font-size: 12px;
	}

	.hero__actions {
		flex-direction: column;
	}

	.hero__actions .btn {
		text-align: center;
		justify-content: center;
	}

	.section__header {
		margin-bottom: 32px;
	}

	.contact-form {
		padding: var(--content-padding);
	}

	.footer-inner,
	.footer-bottom__inner {
		flex-direction: column;
		text-align: center;
	}

	.site-footer {
		padding: 32px 0;
	}

	.skills-content {
		gap: 40px;
	}

	.contact-info {
		gap: 24px;
	}

	.blog-grid {
		grid-template-columns: 1fr;
	}

	.blog-grid--home .blog-card:not(:first-child) {
		display: none;
	}

	.project-info-bar {
		gap: 20px;
	}

	.project-info-bar__item {
		min-width: 140px;
	}

	.project-impact__grid {
		grid-template-columns: 1fr;
	}

	.project-impact__card {
		padding: 28px var(--content-padding);
	}

	.footer-top {
		padding: 40px 0 28px;
	}

	.footer-top__grid {
		flex-direction: column;
		gap: 32px;
	}

	.footer-brand {
		max-width: none;
	}

	.footer-widgets__grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
}

/* ========================================================================
   Responsive — Small Mobile (480px)
   ======================================================================== */

@media (max-width: 480px) {
	:root {
		--section-spacing: 44px;
		--content-padding: 20px;
	}

	.site-header {
		border-radius: 0 0 14px 14px;
	}

	.hero .container {
		padding-top: 20px;
		padding-bottom: 24px;
	}

	.hero__description {
		font-size: 1rem;
		margin-bottom: 24px;
	}

	.hero__stats {
		margin-top: 32px;
		padding-top: 24px;
	}

	.hero__stat-number {
		font-size: 1.35rem;
	}

	.hero__stat-label {
		font-size: 11px;
	}

	.hero__badge {
		margin-bottom: 20px;
	}

	.hero__title {
		margin-bottom: 16px;
	}

	.service-card {
		padding: 24px var(--content-padding);
	}

	.portfolio-card__body {
		padding: 20px var(--content-padding) var(--content-padding);
	}

	.section__header {
		margin-bottom: 28px;
	}

	.section__title {
		margin-bottom: 14px;
	}

	.approach-list {
		gap: 18px;
	}

	.site-footer {
		padding: 28px 0;
	}

	.footer-widgets {
		padding: 40px 0 24px;
		margin-bottom: 24px;
	}

	.project-hero__desc {
		font-size: 1rem;
	}

	.project-info-bar {
		flex-direction: column;
		gap: 16px;
	}
}
