/*
Theme Name: ZebraFolio
Theme URI: https://zebrafolio.com
Author: ZebraFolio
Author URI: https://zebrafolio.com
Description: A modern glassmorphism developer portfolio block theme with soft gradient backgrounds, orange accents, and blue secondary tones. Built for WordPress Full Site Editing. Clean, elegant, and fast — perfect for developers, designers, and freelancers.
Requires at least: 6.3
Tested up to: 6.7
Requires PHP: 7.4
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: zebrafolio
Tags: full-site-editing, block-themes, portfolio, one-column, custom-colors, custom-logo, custom-menu, featured-images, translation-ready, accessibility-ready, wide-blocks, block-patterns, rtl-language-support, sticky-post, threaded-comments
*/

/* ===== GLASSMORPHISM CARDS ===== */
.zf-glass-card {
	background: rgba(255, 255, 255, 0.38);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(255, 255, 255, 0.55);
	box-shadow: 0 8px 32px rgba(30, 100, 200, 0.08);
}

/* ===== HERO ===== */
.zf-hero-wrap {
	position: relative;
	overflow: hidden;
}
.zf-hero-wrap::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 15% 60%, rgba(173, 216, 255, 0.45) 0%, transparent 55%),
		radial-gradient(ellipse at 85% 25%, rgba(255, 180, 100, 0.22) 0%, transparent 50%),
		radial-gradient(ellipse at 50% 90%, rgba(100, 160, 255, 0.18) 0%, transparent 55%);
	z-index: 0;
}
.zf-hero-wrap .wp-block-cover__inner-container {
	position: relative;
	z-index: 1;
}

/* ===== GRADIENT TEXT ===== */
.zf-gradient-text {
	background: linear-gradient(135deg, #ffffff 0%, #BAE6FF 45%, #FF8C42 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* ===== SECTION LABEL ===== */
.zf-section-label {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent-orange);
	margin-bottom: 0.75rem;
}
.zf-section-label::before {
	content: '';
	display: inline-block;
	width: 28px;
	height: 2px;
	background: var(--wp--preset--color--accent-orange);
	border-radius: 2px;
}

/* ===== PROJECT CARDS ===== */
.zf-project-card {
	background: rgba(255, 255, 255, 0.42);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid rgba(255, 255, 255, 0.6);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(30, 80, 180, 0.07);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.zf-project-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 16px 48px rgba(30, 80, 180, 0.14);
}
.zf-project-card__img {
	aspect-ratio: 16/10;
	overflow: hidden;
}
.zf-project-card__img img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}
.zf-project-card:hover .zf-project-card__img img {
	transform: scale(1.05);
}
.zf-project-card__body { padding: 1.5rem; }
.zf-project-card__tag {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 500;
	padding: 0.2rem 0.7rem;
	background: rgba(30, 100, 255, 0.08);
	color: var(--wp--preset--color--accent-blue);
	border: 1px solid rgba(30, 100, 255, 0.15);
	border-radius: 100px;
	margin: 0 0.25rem 0.25rem 0;
}
.zf-project-card__title {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0.5rem 0 0.4rem;
	color: var(--wp--preset--color--text-dark);
}
.zf-project-card__desc {
	font-size: 0.875rem;
	color: var(--wp--preset--color--text-muted);
	line-height: 1.65;
	margin: 0 0 1rem;
}
.zf-project-card__links {
	display: flex; gap: 0.75rem;
}
.zf-link-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--wp--preset--color--text-dark);
	text-decoration: none;
	padding: 0.35rem 0.875rem;
	border: 1px solid rgba(0,0,0,0.12);
	border-radius: 8px;
	transition: all 0.2s;
}
.zf-link-btn:hover {
	background: var(--wp--preset--color--accent-orange);
	color: #fff;
	border-color: var(--wp--preset--color--accent-orange);
}

/* ===== SKILL TAGS ===== */
.zf-skill-tag {
	display: inline-flex;
	align-items: center;
	font-size: 0.85rem;
	font-weight: 500;
	padding: 0.4rem 1rem;
	background: rgba(255,255,255,0.5);
	border: 1px solid rgba(255,255,255,0.7);
	border-radius: 10px;
	backdrop-filter: blur(8px);
	transition: all 0.2s;
	color: var(--wp--preset--color--text-dark);
}
.zf-skill-tag:hover {
	background: var(--wp--preset--color--accent-orange);
	color: #fff;
	border-color: var(--wp--preset--color--accent-orange);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(255,120,50,0.25);
}

/* ===== TIMELINE ===== */
.zf-timeline { padding-left: 2rem; position: relative; }
.zf-timeline::before {
	content: '';
	position: absolute;
	left: 0; top: 8px; bottom: 0;
	width: 2px;
	background: linear-gradient(to bottom, var(--wp--preset--color--accent-orange), var(--wp--preset--color--accent-blue), rgba(100,160,255,0.1));
}
.zf-timeline-item { position: relative; padding-bottom: 2.5rem; }
.zf-timeline-item:last-child { padding-bottom: 0; }
.zf-timeline-dot {
	position: absolute;
	left: -2rem;
	top: 5px;
	width: 12px; height: 12px;
	background: var(--wp--preset--color--accent-orange);
	border-radius: 50%;
	margin-left: -5px;
	box-shadow: 0 0 0 3px rgba(255,255,255,0.9), 0 0 0 5px rgba(255,120,50,0.2);
}
.zf-timeline-period {
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent-orange);
	margin-bottom: 0.2rem;
}
.zf-timeline-role {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--wp--preset--color--text-dark);
	margin-bottom: 0.15rem;
}
.zf-timeline-company {
	font-size: 0.85rem;
	color: var(--wp--preset--color--text-muted);
	margin-bottom: 0.5rem;
}
.zf-timeline-desc {
	font-size: 0.875rem;
	color: var(--wp--preset--color--text-muted);
	line-height: 1.7;
}

/* ===== TESTIMONIAL ===== */
.zf-testimonial {
	background: rgba(255,255,255,0.4);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(255,255,255,0.65);
	border-radius: 20px;
	padding: 2rem;
	box-shadow: 0 4px 24px rgba(30,80,180,0.06);
	transition: transform 0.25s, box-shadow 0.25s;
}
.zf-testimonial:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(30,80,180,0.12);
}
.zf-testimonial__quote {
	font-size: 3.5rem;
	line-height: 1;
	color: var(--wp--preset--color--accent-orange);
	opacity: 0.5;
	margin-bottom: -0.5rem;
	display: block;
}
.zf-testimonial__stars { color: #F5A623; font-size: 0.85rem; margin-bottom: 0.5rem; }
.zf-testimonial__text {
	font-style: italic;
	font-size: 0.95rem;
	line-height: 1.8;
	color: var(--wp--preset--color--text-dark);
	margin-bottom: 1.25rem;
}
.zf-testimonial__author { display: flex; align-items: center; gap: 0.875rem; }
.zf-testimonial__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.zf-testimonial__name { font-weight: 700; font-size: 0.9rem; margin: 0; }
.zf-testimonial__role { font-size: 0.75rem; color: var(--wp--preset--color--text-muted); margin: 0; }

/* ===== SERVICE CARD ===== */
.zf-service {
	background: rgba(255,255,255,0.38);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid rgba(255,255,255,0.55);
	border-radius: 18px;
	padding: 2rem;
	position: relative;
	overflow: hidden;
	transition: transform 0.25s, box-shadow 0.25s;
	box-shadow: 0 4px 20px rgba(30,80,180,0.05);
}
.zf-service::after {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--wp--preset--color--accent-orange), var(--wp--preset--color--accent-blue));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.3s ease;
}
.zf-service:hover { transform: translateY(-5px); box-shadow: 0 12px 40px rgba(30,80,180,0.1); }
.zf-service:hover::after { transform: scaleX(1); }
.zf-service__icon {
	width: 52px; height: 52px;
	background: linear-gradient(135deg, rgba(255,140,66,0.12), rgba(30,100,255,0.08));
	border-radius: 14px;
	display: flex; align-items: center; justify-content: center;
	margin-bottom: 1.25rem;
	font-size: 1.4rem;
}
.zf-service__title { font-size: 1.1rem; font-weight: 700; margin: 0 0 0.5rem; }
.zf-service__desc { font-size: 0.875rem; color: var(--wp--preset--color--text-muted); line-height: 1.7; margin: 0; }

/* ===== STATS ===== */
.zf-stat { text-align: center; padding: 2rem 1rem; }
.zf-stat__num {
	display: block;
	font-size: clamp(2.5rem, 6vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1;
	margin-bottom: 0.4rem;
}
.zf-stat__label { font-size: 0.875rem; color: rgba(255,255,255,0.65); }

/* ===== HEADER ===== */
.zf-header {
	position: sticky; top: 0; z-index: 100;
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	background: rgba(255,255,255,0.8);
	border-bottom: 1px solid rgba(200,220,255,0.3);
	transition: box-shadow 0.3s;
}
.zf-header.scrolled {
	box-shadow: 0 2px 20px rgba(30,80,180,0.08);
}

/* ===== SKIP LINK ===== */
.skip-link {
	position: absolute; top: -100%; left: 1rem; z-index: 9999;
	padding: 0.5rem 1rem;
	background: var(--wp--preset--color--accent-orange);
	color: #fff; font-weight: 600;
	border-radius: 0 0 8px 8px;
	text-decoration: none;
	transition: top 0.2s;
}
.skip-link:focus { top: 0; }

/* ===== SOCIAL LINKS ===== */
.zf-social-link {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 38px; height: 38px;
	border-radius: 10px;
	background: rgba(255,255,255,0.5);
	border: 1px solid rgba(255,255,255,0.7);
	color: var(--wp--preset--color--text-dark);
	text-decoration: none;
	transition: all 0.2s;
	backdrop-filter: blur(8px);
}
.zf-social-link:hover {
	background: var(--wp--preset--color--accent-orange);
	color: #fff;
	border-color: var(--wp--preset--color--accent-orange);
	transform: translateY(-2px);
}

/* ===== FOOTER ===== */
.zf-footer {
	border-top: 1px solid rgba(200,220,255,0.35);
	background: linear-gradient(to bottom, rgba(240,248,255,0.7), rgba(230,242,255,0.9));
}

/* ===== ANIMATIONS ===== */
.animations-hidden-item {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.65s ease, transform 0.65s ease;
}
.animations-show-item {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

/* ===== BUTTONS ===== */
.wp-block-button__link {
	transition: all 0.22s ease;
}
.wp-block-button__link:hover {
	transform: translateY(-2px);
}
.is-style-outline .wp-block-button__link {
	background: transparent;
}

/* ===== FORM ===== */
.zf-form-field { display: flex; flex-direction: column; gap: 0.35rem; }
.zf-form-field label { font-size: 0.875rem; font-weight: 500; }
.zf-form-field input,
.zf-form-field textarea,
.zf-form-field select {
	width: 100%;
	padding: 0.75rem 1rem;
	background: rgba(255,255,255,0.65);
	border: 1.5px solid rgba(200,220,255,0.5);
	border-radius: 10px;
	font-family: var(--wp--preset--font-family--inter);
	font-size: 0.9rem;
	backdrop-filter: blur(8px);
	transition: border-color 0.2s, box-shadow 0.2s;
}
.zf-form-field input:focus,
.zf-form-field textarea:focus {
	outline: none;
	border-color: var(--wp--preset--color--accent-blue);
	box-shadow: 0 0 0 3px rgba(30,100,255,0.08);
}
.zf-form-field textarea { min-height: 130px; resize: vertical; }

/* ===== 404 ===== */
.zf-404-num {
	display: block; text-align: center;
	font-size: clamp(7rem, 20vw, 14rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1;
	background: linear-gradient(135deg, rgba(173,216,255,0.4), rgba(255,140,66,0.3));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* ===== SCROLL TO TOP ===== */
#scroll-to-top-btn {
	position: fixed; bottom: 2rem; right: 2rem; z-index: 999;
	width: 44px; height: 44px;
	background: var(--wp--preset--color--accent-orange);
	color: #fff;
	border: none; border-radius: 12px; cursor: pointer;
	display: none; align-items: center; justify-content: center;
	box-shadow: 0 4px 20px rgba(255,120,50,0.3);
	transition: all 0.2s;
}
#scroll-to-top-btn:hover { transform: translateY(-3px); box-shadow: 0 8px 30px rgba(255,120,50,0.4); }

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
	.zf-timeline { padding-left: 1.25rem; }
	.zf-stat__num { font-size: 2.5rem; }
}
