/* StudioFlicks — header.css */

/* ── Site header ────────────────────────────────────────────────────────────── */
.sf-header {
	position: sticky;
	top: 0;
	z-index: 100;
	height: var(--sf-nav-height);
	background: #0d0d0d;
	border-bottom: 1px solid rgba(255,255,255,0.07);
	display: flex;
	align-items: center;
}
.sf-header:not(.sf-header--sticky) { position: relative; }

.sf-header__inner {
	display: flex;
	align-items: center;
	gap: 0;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

/* ── Logo ───────────────────────────────────────────────────────────────────── */
.sf-header__logo {
	flex-shrink: 0;
	margin-right: 28px;
	text-decoration: none;
}
.sf-header__logo img { height: 34px; width: auto; }
.sf-header__logo-text {
	font-size: 18px;
	font-weight: 800;
	color: #fff;
	font-family: var(--sf-font-heading);
	letter-spacing: -0.3px;
}
.sf-header__logo-text span { color: var(--sf-accent); }

/* ── Primary nav ────────────────────────────────────────────────────────────── */
.sf-header__nav {
	flex: 1;
	display: flex;
	align-items: center;
}

.sf-nav__list {
	display: flex;
	align-items: center;
	gap: 2px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.sf-nav__item { position: relative; }

.sf-nav__link {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 6px 11px;
	font-size: 12px;
	font-weight: 500;
	color: rgba(255,255,255,0.72);
	font-family: var(--sf-font-ui);
	border-radius: 5px;
	transition: color var(--sf-transition), background var(--sf-transition);
	white-space: nowrap;
	text-decoration: none;
}
.sf-nav__link:hover, .sf-nav__item.current-menu-item > .sf-nav__link,
.sf-nav__item.current-menu-ancestor > .sf-nav__link {
	color: #fff;
	background: rgba(255,255,255,0.07);
}
.sf-nav__link--has-children::after { content: '▾'; font-size: 9px; opacity: 0.5; }

/* Dropdown */
.sf-nav__dropdown {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 170px;
	background: #1a1a1a;
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: var(--sf-radius);
	padding: 6px 0;
	opacity: 0;
	pointer-events: none;
	transform: translateY(-6px);
	transition: opacity 0.15s, transform 0.15s;
	list-style: none;
	margin: 0;
}
.sf-nav__item:hover .sf-nav__dropdown,
.sf-nav__item:focus-within .sf-nav__dropdown {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}
.sf-nav__dropdown-link {
	display: block;
	padding: 7px 14px;
	font-size: 12px;
	font-weight: 500;
	color: rgba(255,255,255,0.65);
	font-family: var(--sf-font-ui);
	text-decoration: none;
	transition: color var(--sf-transition), background var(--sf-transition);
}
.sf-nav__dropdown-link:hover { color: #fff; background: rgba(255,255,255,0.05); }

/* ── Header actions ─────────────────────────────────────────────────────────── */
.sf-header__actions {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-left: auto;
	flex-shrink: 0;
}

/* ── Search ─────────────────────────────────────────────────────────────────── */
.sf-search-toggle {
	background: none;
	border: none;
	color: rgba(255,255,255,0.65);
	padding: 6px;
	border-radius: 5px;
	display: flex;
	align-items: center;
	transition: color var(--sf-transition), background var(--sf-transition);
}
.sf-search-toggle:hover { color: #fff; background: rgba(255,255,255,0.07); }
.sf-search-toggle svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2; }

.sf-search-panel {
	position: absolute;
	top: var(--sf-nav-height);
	left: 0;
	right: 0;
	background: #111;
	border-bottom: 1px solid rgba(255,255,255,0.08);
	padding: 12px 20px;
	display: none;
	z-index: 99;
}
.sf-search-panel.is-open { display: block; }

.sf-search-input-wrap {
	max-width: 600px;
	margin: 0 auto;
	position: relative;
}
.sf-search-input {
	width: 100%;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--sf-radius);
	color: #fff;
	font-size: 14px;
	padding: 10px 40px 10px 14px;
	outline: none;
	font-family: var(--sf-font-ui);
}
.sf-search-input::placeholder { color: rgba(255,255,255,0.35); }
.sf-search-input:focus { border-color: var(--sf-accent); }

.sf-search-results {
	position: absolute;
	top: calc(100% + 4px);
	left: 0; right: 0;
	background: #1a1a1a;
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: var(--sf-radius);
	max-height: 360px;
	overflow-y: auto;
	display: none;
}
.sf-search-results.has-results { display: block; }

.sf-search-result {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 12px;
	text-decoration: none;
	border-bottom: 1px solid rgba(255,255,255,0.05);
	transition: background var(--sf-transition);
}
.sf-search-result:last-child { border-bottom: none; }
.sf-search-result:hover { background: rgba(255,255,255,0.05); }
.sf-search-result-thumb { width: 36px; height: 36px; border-radius: 4px; object-fit: cover; flex-shrink: 0; }
.sf-search-result-title { font-size: 13px; font-weight: 600; color: #fff; }
.sf-search-result-meta { font-size: 11px; color: rgba(255,255,255,0.45); }
.sf-search-result-type { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 3px; background: rgba(230,57,70,0.15); color: var(--sf-accent); }

/* ── Watchlist icon button ───────────────────────────────────────────────────── */
.sf-header-watchlist {
	background: none;
	border: none;
	color: rgba(255,255,255,0.65);
	padding: 6px;
	border-radius: 5px;
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 11px;
	font-weight: 500;
	font-family: var(--sf-font-ui);
	text-decoration: none;
	transition: color var(--sf-transition), background var(--sf-transition);
}
.sf-header-watchlist:hover { color: #fff; background: rgba(255,255,255,0.07); }
.sf-header-watchlist svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; }

/* ── Auth buttons ────────────────────────────────────────────────────────────── */
.sf-btn-signin {
	font-size: 11px;
	font-weight: 600;
	padding: 5px 12px;
	border-radius: 5px;
	color: rgba(255,255,255,0.7);
	border: 1px solid rgba(255,255,255,0.15);
	background: transparent;
	font-family: var(--sf-font-ui);
	transition: all var(--sf-transition);
	text-decoration: none;
}
.sf-btn-signin:hover { color: #fff; border-color: rgba(255,255,255,0.4); }

.sf-btn-join {
	font-size: 11px;
	font-weight: 600;
	padding: 5px 12px;
	border-radius: 5px;
	background: var(--sf-accent);
	color: #fff;
	border: 1px solid var(--sf-accent);
	font-family: var(--sf-font-ui);
	transition: background var(--sf-transition);
	text-decoration: none;
}
.sf-btn-join:hover { background: var(--sf-accent-dark); border-color: var(--sf-accent-dark); color: #fff; }

/* ── Hamburger ───────────────────────────────────────────────────────────────── */
.sf-hamburger {
	display: none;
	background: none;
	border: none;
	color: rgba(255,255,255,0.7);
	padding: 6px;
	border-radius: 5px;
	flex-direction: column;
	gap: 4px;
	cursor: pointer;
}
.sf-hamburger span {
	display: block;
	width: 18px;
	height: 2px;
	background: currentColor;
	border-radius: 2px;
	transition: transform var(--sf-transition), opacity var(--sf-transition);
}
.sf-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.sf-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.sf-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ── Mobile nav ──────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
	.sf-hamburger { display: flex; }
	.sf-header__nav { display: none; }
	.sf-header__nav.is-open {
		display: flex;
		flex-direction: column;
		position: fixed;
		top: var(--sf-nav-height);
		left: 0; right: 0; bottom: 0;
		background: #0d0d0d;
		z-index: 98;
		overflow-y: auto;
		padding: 16px 20px;
	}
	.sf-nav__list { flex-direction: column; align-items: flex-start; gap: 0; }
	.sf-nav__link { font-size: 15px; padding: 10px 0; }
	.sf-nav__dropdown { position: static; opacity: 1; pointer-events: auto; transform: none; background: transparent; border: none; border-left: 2px solid rgba(255,255,255,0.1); margin: 4px 0 4px 12px; padding: 4px 0; }
	.sf-nav__dropdown-link { font-size: 13px; padding: 6px 10px; }
}

@media (max-width: 480px) {
	.sf-header__inner { padding: 0 16px; }
	.sf-btn-join, .sf-btn-signin { display: none; }
}
