*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
	--bg:          #0a0a0a;
	--bg2:         #0f0f0f;
	--card:        #161616;
	--blue:        #00aeef;
	--blue-light:  #6dd5fa;
	--blue-dim:    rgba(0, 174, 239, 0.09);
	--blue-glow:   rgba(0, 174, 239, 0.18);
	--text:        #ffffff;
	--text-soft:   #d0d0d0;
	--muted:       #555555;
	--border:      rgba(0, 174, 239, 0.15);
	--border-soft: rgba(255,255,255,0.07);
}
html { scroll-behavior: smooth; }
body {
	background: var(--bg);
	color: var(--text);
	font-family: 'Heebo', sans-serif;
	font-weight: 300;
	overflow-x: hidden;
	cursor: none;
}
::selection { background: var(--blue); color: #000; }
/* ─── CURSOR ─── */
#cursor {
	position: fixed;
	width: 10px; height: 10px;
	background: var(--blue);
	border-radius: 50%;
	pointer-events: none;
	z-index: 99999;
	transform: translate(-50%,-50%);
	transition: width .25s ease, height .25s ease, background .25s ease;
}
#cursor-ring {
	position: fixed;
	width: 42px; height: 42px;
	border: 1px solid rgba(0,174,239,.4);
	border-radius: 50%;
	pointer-events: none;
	z-index: 99998;
	transform: translate(-50%,-50%);
	transition: border-color .3s ease;
}
body.cursor-hover #cursor {
	width: 46px; height: 46px;
	background: transparent;
	border: 1.5px solid var(--blue);
}
body.cursor-hover #cursor-ring { border-color: transparent; }
/* ─── LOADER ─── */
#loader {
	position: fixed; inset: 0;
	background: var(--bg);
	z-index: 100000;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: 2rem;
	transition: opacity .9s ease .2s, visibility .9s ease .2s;
}
#loader.out { opacity: 0; visibility: hidden; }
.loader-logo-img {
	width: 140px;
	filter: invert(1) brightness(2);
	opacity: 0;
	animation: fadeIn .5s ease .3s forwards;
}
.loader-track {
	width: 200px; height: 2px;
	background: rgba(255,255,255,.07);
	border-radius: 2px;
	position: relative; overflow: hidden;
	opacity: 0; animation: fadeIn .3s ease .7s forwards;
}
.loader-fill {
	position: absolute; left: -100%; top: 0;
	width: 100%; height: 100%;
	background: var(--blue);
	animation: fill 1.8s cubic-bezier(.4,0,.2,1) .8s forwards;
}
@keyframes fill { to { left: 0; } }
@keyframes fadeIn { to { opacity: 1; } }
/* ─── SIDE NAV ─── */
#side-nav {
	position: fixed; right: 2rem; top: 50%;
	transform: translateY(-50%);
	z-index: 500;
	display: flex; flex-direction: column;
	align-items: flex-end; gap: 1.2rem;
}
.ndot {
	display: flex; align-items: center; gap: .8rem;
	cursor: pointer;
}
.ndot-label {
	font-size: .62rem; letter-spacing: .18em;
	text-transform: uppercase; color: var(--muted);
	opacity: 0;
	transition: opacity .3s ease, color .3s ease;
	white-space: nowrap; font-weight: 400;
}
.ndot:hover .ndot-label, .ndot.active .ndot-label { opacity: 1; color: var(--blue); }
.ndot-pip {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--muted);
	transition: background .3s ease, transform .3s ease, box-shadow .3s ease;
}
.ndot.active .ndot-pip {
	background: var(--blue);
	transform: scale(1.7);
	box-shadow: 0 0 10px rgba(0,174,239,.7);
}
.ndot:hover .ndot-pip { background: var(--blue-light); }
/* ─── HERO ─── */
#hero {
	position: relative;
	height: 100vh; min-height: 680px;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	text-align: center; overflow: hidden;
}
/* glow orb */
.hero-orb {
	position: absolute;
	width: 600px; height: 600px;
	background: radial-gradient(circle, rgba(0,174,239,.08) 0%, transparent 65%);
	border-radius: 50%;
	animation: orbPulse 5s ease-in-out infinite alternate;
	pointer-events: none;
}
@keyframes orbPulse {
	from { transform: scale(.8); opacity: .5; }
	to   { transform: scale(1.2); opacity: 1; }
}
/* rotating rings */
.hero-ring {
	position: absolute;
	border-radius: 50%;
	border: 1px solid var(--border);
	pointer-events: none;
	animation: spin linear infinite;
}
.ring-1 { width: 440px; height: 440px; animation-duration: 28s; }
.ring-2 { width: 650px; height: 650px; animation-duration: 48s; animation-direction: reverse; border-color: rgba(0,174,239,.06); }
@keyframes spin { to { transform: rotate(360deg); } }
/* top bar with logo */
.hero-topbar {
	position: absolute; top: 2.5rem; left: 50%;
	transform: translateX(-50%);
	opacity: 0; animation: fadeIn .6s ease 2.6s forwards;
}
.hero-topbar img {
	height: 32px;
	filter: invert(1) brightness(2);
}
.hero-content { position: relative; z-index: 2; }
.hero-eyebrow {
	display: inline-block;
	font-size: .65rem; font-weight: 500;
	letter-spacing: .45em; text-transform: uppercase;
	color: var(--blue); margin-bottom: 2rem;
	opacity: 0; animation: slideUp .7s ease 2.7s forwards;
}
.hero-h1 {
	font-size: clamp(3.5rem, 9vw, 8rem);
	font-weight: 900; line-height: 1.0;
	letter-spacing: -.03em; margin-bottom: 2rem;
}
.hero-line { display: block; overflow: hidden; }
.hero-word {
	display: block;
	opacity: 0; transform: translateY(110%);
	animation: slideUp .85s cubic-bezier(.16,1,.3,1) forwards;
}
.hero-line:nth-child(1) .hero-word { animation-delay: 2.8s; }
.hero-line:nth-child(2) .hero-word { animation-delay: 2.96s; color: var(--blue); }
.hero-line:nth-child(3) .hero-word { animation-delay: 3.12s; }
.hero-sub {
	font-size: clamp(.82rem, 1.8vw, 1rem);
	font-weight: 300; color: var(--text);
	line-height: 1.8; letter-spacing: .03em;
	max-width: 460px; margin: 0 auto 3.5rem;
	opacity: 0; animation: slideUp .7s ease 3.3s forwards;
}
/* Ira byline */
.hero-by {
	display: flex; align-items: center; justify-content: center;
	gap: 1.2rem; margin-bottom: 2.5rem;
	opacity: 0; animation: slideUp .7s ease 3.1s forwards;
}
.by-avatar {
	width: 56px; height: 56px;
	border-radius: 50%;
	border: 2px solid var(--blue);
	object-fit: cover;
	object-position: center center;
	box-shadow: 0 0 0 4px rgba(0,174,239,.12), 0 0 20px rgba(0,174,239,.2);
	transition: box-shadow .3s ease;
	flex-shrink: 0;
}
.by-avatar:hover { box-shadow: 0 0 0 4px rgba(0,174,239,.3), 0 0 30px rgba(0,174,239,.4); }
.by-line { width: 32px; height: 1px; background: rgba(255,255,255,.2); }
.by-text {
	font-size: .76rem; font-weight: 400;
	letter-spacing: .22em; color: var(--text-soft);
}
.by-name {
	font-size: .76rem; font-weight: 700;
	letter-spacing: .12em; color: var(--text);
}
.hero-divider {
	display: flex; align-items: center; gap: 1.2rem;
	justify-content: center;
	opacity: 0; animation: fadeIn .7s ease 3.6s forwards;
}
.h-line { width: 48px; height: 1px; background: var(--blue); }
.h-text {
	font-size: .65rem; font-weight: 500;
	letter-spacing: .35em; text-transform: uppercase;
	color: var(--blue);
}
.hero-scroll {
	position: absolute; bottom: 2.5rem;
	display: flex; flex-direction: column;
	align-items: center; gap: .8rem;
	opacity: 0; animation: fadeIn .6s ease 4s forwards;
}
.hero-scroll span {
	font-size: .58rem; font-weight: 400;
	letter-spacing: .35em; text-transform: uppercase; color: var(--muted);
}
.scroll-bar {
	width: 1px; height: 52px;
	background: linear-gradient(to bottom, var(--blue), transparent);
	transform: scaleY(0); transform-origin: top;
	animation: tickFlow 2.2s ease 4.2s infinite;
}
@keyframes tickFlow {
	0%   { transform: scaleY(0); transform-origin: top; }
	48%  { transform: scaleY(1); transform-origin: top; }
	50%  { transform: scaleY(1); transform-origin: bottom; }
	100% { transform: scaleY(0); transform-origin: bottom; }
}
@keyframes slideUp { to { opacity: 1; transform: translateY(0); } }
/* ─── client-logos BAND ─── */
#clients {
	padding: 5rem 0;
	border-top: 1px solid var(--border-soft);
	border-bottom: 1px solid var(--border-soft);
	overflow: hidden;
	position: relative;
}
.clients-label {
	text-align: center;
	font-size: .62rem; font-weight: 500;
	letter-spacing: .4em; text-transform: uppercase;
	color: var(--muted); margin-bottom: 3rem;
}
.clients-track-wrap {
	overflow: hidden;
	mask-image: linear-gradient(to right, transparent 0%, black 12%, black 88%, transparent 100%);
	-webkit-mask-image: linear-gradient(to right, transparent 0%, black 12%, black 88%, transparent 100%);
}
.clients-track {
	display: flex; align-items: center; gap: 0;
	width: max-content;
	animation: marquee 28s linear infinite;
}
.clients-track:hover { animation-play-state: paused; }
@keyframes marquee {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}
.client-logo {
	flex: 0 0 auto;
	padding: 0 4rem;
	display: flex; align-items: center; justify-content: center;
}
.client-logo img {
	height: 36px; width: auto;
	filter: brightness(0) invert(1);
	opacity: .35;
	transition: opacity .35s ease, filter .35s ease;
}
.client-logo img:hover { opacity: .9; filter: brightness(0) invert(1) drop-shadow(0 0 8px rgba(0,174,239,.6)); }
/* ─── PROJECT SECTIONS ─── */
.proj {
	position: relative;
	padding: 10rem 5vw;
	border-top: 1px solid var(--border-soft);
}
.proj:nth-child(even) { background: var(--bg2); }
/* top accent bar */
.proj-bar {
	position: absolute; top: 0; left: 5vw;
	width: 0; height: 2px;
	background: linear-gradient(to right, var(--blue), transparent);
	transition: width 1.3s cubic-bezier(.16,1,.3,1);
}
.proj.visible .proj-bar { width: min(260px, 30vw); }
.proj-inner { max-width: 1440px; margin: 0 auto; }
.proj-header {
	display: grid;
	grid-template-columns: 1fr 1.6fr;
	gap: 5rem; align-items: start;
	margin-bottom: 6rem;
}
.proj-index {
	font-size: .62rem; font-weight: 500;
	letter-spacing: .4em; color: var(--blue);
	text-transform: uppercase; margin-bottom: 1.2rem;
}
.proj-title {
	font-size: clamp(2.8rem, 5.5vw, 5.5rem);
	font-weight: 900; line-height: 1.05;
	letter-spacing: -.03em; overflow: hidden;
}
.proj-title-inner {
	display: block;
	transform: translateY(105%); opacity: 0;
	transition: transform 1s cubic-bezier(.16,1,.3,1), opacity .5s ease;
}
.proj.visible .proj-title-inner { transform: translateY(0); opacity: 1; }
.proj-desc {
	font-size: clamp(.95rem, 1.6vw, 1.12rem);
	font-weight: 300; line-height: 1.9;
	color: var(--text); margin-bottom: 2rem;
	direction: rtl; text-align: right;
	opacity: 0; transform: translateY(14px);
	transition: opacity .8s ease .2s, transform .8s ease .2s;
}
.proj.visible .proj-desc { opacity: 1; transform: translateY(0); }
/* project website link */
.proj-link {
	display: inline-flex; align-items: center; gap: .6rem;
	font-size: .72rem; font-weight: 500;
	letter-spacing: .12em; text-decoration: none;
	color: var(--blue);
	border: 1px solid var(--border);
	padding: .55rem 1.1rem;
	transition: background .25s ease, border-color .25s ease, gap .25s ease;
	margin-bottom: 2rem;
	opacity: 0; transform: translateY(10px);
	transition: opacity .8s ease .12s, transform .8s ease .12s, background .25s ease, border-color .25s ease;
}
.proj.visible .proj-link { opacity: 1; transform: translateY(0); }
.proj-link:hover { background: var(--blue-dim); border-color: var(--blue); gap: .9rem; }
.proj-link-arrow { font-size: .85rem; }
.proj-tags {
	display: flex; flex-wrap: wrap; gap: .5rem;
	direction: rtl; justify-content: flex-start;
	opacity: 0; transform: translateY(10px);
	transition: opacity .8s ease .35s, transform .8s ease .35s;
}
.proj.visible .proj-tags { opacity: 1; transform: translateY(0); }
.ptag {
	font-size: .6rem; font-weight: 500;
	letter-spacing: .18em; text-transform: uppercase;
	color: var(--blue);
	border: 1px solid var(--border);
	padding: .3rem .85rem;
	transition: background .3s ease, border-color .3s ease;
}
.ptag:hover { background: var(--blue-dim); border-color: var(--blue); }
/* ─── MASONRY GRID ─── */
.proj-grid { columns: 3; column-gap: 1.2rem; }
.grid-item {
	break-inside: avoid; margin-bottom: 1.2rem;
	position: relative; overflow: hidden;
	cursor: pointer;
	opacity: 0; transform: translateY(28px);
	transition: opacity .6s ease, transform .6s cubic-bezier(.16,1,.3,1), box-shadow .35s ease;
}
.grid-item.on { opacity: 1; transform: translateY(0); }
.grid-item:hover { box-shadow: 0 24px 60px rgba(0,0,0,.6), 0 0 0 1px rgba(0,174,239,.15); }
.grid-item img {
	width: 100%; display: block;
	transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.grid-item:hover img { transform: scale(1.045); }
.grid-cap {
	position: absolute; inset: 0;
	background: linear-gradient(to top, rgba(10,10,10,.85) 0%, transparent 55%);
	display: flex; align-items: flex-end; padding: 1.4rem;
	opacity: 0; transition: opacity .3s ease;
}
.grid-item:hover .grid-cap { opacity: 1; }
.grid-cap span {
	font-size: .62rem; font-weight: 500;
	letter-spacing: .2em; text-transform: uppercase;
	color: var(--blue-light);
}
/* hover border flash */
.grid-item::after {
	content: '';
	position: absolute; inset: 0;
	border: 1px solid rgba(0,174,239,0);
	transition: border-color .3s ease;
	pointer-events: none;
}
.grid-item:hover::after { border-color: rgba(0,174,239,.3); }
/* ─── LIGHTBOX ─── */
#lb {
	position: fixed;
	inset: 0;
	background: rgba(5,5,5,.97);
	backdrop-filter: blur(28px) saturate(1.1);
	z-index: 50000;
	opacity: 0;
	visibility: hidden;
	transition: opacity .35s ease, visibility .35s ease;
}
#lb.on { opacity: 1; visibility: visible; }
/* inner wrapper — centers image horizontally, stacks vertically */
#lb-inner {
	height: 100%;
	overflow: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 80px 0 60px;   /* room for top/bottom bars */
}
#lb-img {
	width: 100%;             /* full viewport width */
	height: auto;            /* natural height — allows tall images to scroll */
	display: block;
	box-shadow: 0 0 0 1px rgba(0,174,239,.1);
	transition: opacity .25s ease;
}
/* fixed top bar: close + counter */
#lb-topbar {
	position: fixed; top: 0; left: 0; right: 0;
	height: 60px;
	display: flex; align-items: center; justify-content: space-between;
	padding: 0 1.5rem;
	background: linear-gradient(to bottom, rgba(5,5,5,.95), transparent);
	z-index: 50001;
	pointer-events: none;   /* let clicks pass through except buttons */
}
#lb-counter {
	font-size: .62rem; font-weight: 400;
	letter-spacing: .3em; color: var(--muted);
	text-transform: uppercase;
	pointer-events: none;
}
/* fixed bottom bar: prev + next */
#lb-bottombar {
	position: fixed; bottom: 0; left: 0; right: 0;
	height: 60px;
	display: flex; align-items: center; justify-content: center;
	gap: 1rem;
	background: linear-gradient(to top, rgba(5,5,5,.95), transparent);
	z-index: 50001;
}
.lb-btn {
	width: 46px; height: 46px;
	border: 1px solid rgba(0,174,239,.25);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	cursor: pointer; color: var(--blue);
	font-size: .9rem; font-weight: 300;
	transition: background .25s ease, border-color .25s ease, transform .2s ease;
	user-select: none; pointer-events: all;
	background: rgba(5,5,5,.7);
}
.lb-btn:hover { background: var(--blue-dim); border-color: var(--blue); transform: scale(1.08); }
/* ─── FOOTER ─── */
	footer {
	padding: 7rem 5vw 4rem;
	text-align: center;
	border-top: 1px solid var(--border-soft);
	position: relative; overflow: hidden;
}
.footer-glow {
	position: absolute; bottom: -80px; left: 50%;
	transform: translateX(-50%);
	width: 500px; height: 300px;
	background: radial-gradient(ellipse, rgba(0,174,239,.06) 0%, transparent 70%);
	pointer-events: none;
}
.footer-logo {
	margin-bottom: 2.5rem;
}
.footer-logo img {
	height: 38px;
	filter: invert(1) brightness(2);
	opacity: .7;
}
.footer-tagline {
	font-size: clamp(1.4rem, 3vw, 2.4rem);
	font-weight: 700; color: var(--text);
	margin-bottom: .8rem;
}
.footer-sub {
	font-size: .72rem; font-weight: 400;
	letter-spacing: .25em; text-transform: uppercase;
	color: var(--muted); margin-bottom: 4rem;
}
.footer-divider {
	width: 1px; height: 56px;
	background: linear-gradient(to bottom, var(--blue), transparent);
	margin: 0 auto 4rem;
}
.footer-stats {
	display: flex; gap: 4rem;
	justify-content: center; align-items: center;
	margin-bottom: 4rem;
}
.fstat { display: flex; flex-direction: column; align-items: center; gap: .4rem; }
.fstat-num {
	font-size: 2rem; font-weight: 800;
	color: var(--blue); line-height: 1;
}
.fstat-label {
	font-size: .6rem; font-weight: 400;
	letter-spacing: .28em; text-transform: uppercase; color: var(--muted);
}
.footer-bottom {
	padding-top: 2rem;
	border-top: 1px solid rgba(255,255,255,.04);
	font-size: .6rem; font-weight: 300;
	letter-spacing: .22em; text-transform: uppercase; color: var(--muted);
}
/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
	.proj-grid { columns: 2; }
	.proj-header { grid-template-columns: 1fr; gap: 2.5rem; }
	.footer-stats { gap: 2.5rem; }
}
@media (max-width: 640px) {
	.proj-grid { columns: 1; }
	.proj { padding: 6rem 1.5rem; }
	#side-nav { display: none; }
	.hero-h1 { font-size: clamp(3rem, 13vw, 4.5rem); }
	.footer-stats { gap: 1.8rem; }
	.fstat-num { font-size: 1.5rem; }
}