/* ── RF Menu Widget ─────────────────────────────────────────
   Base styles. Dynamic values (colors, typography, spacing)
   are handled by Elementor controls via selectors.
──────────────────────────────────────────────────────────── */

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

.rfm-root {
	position: relative;
	width: 100%;
	font-family: 'Poppins', sans-serif;
}

/* ── Navbar row ────────────────────────────────────────── */
.rfm-navbar-row {
	position: relative;
	z-index: 300;
	display: flex;
	justify-content: center;
}

/* ── Pill Navbar ───────────────────────────────────────── */
.rfm-navbar {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	background: #fff;
	border-radius: 999px;
	padding: 6px 10px;
}

.rfm-nav-btn,
.rfm-nav-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: none;
	border: none;
	font-family: 'Poppins', sans-serif;
	font-size: 14px;
	font-weight: 400;
	color: #3B3E45;
	text-decoration: none;
	cursor: pointer;
	padding: 7px 13px;
	border-radius: 999px;
	white-space: nowrap;
	line-height: 1;
	transition: font-weight 0.18s;
}

.rfm-nav-btn:hover,
.rfm-nav-link:hover,
.rfm-nav-btn:focus,
.rfm-nav-link:focus,
.rfm-nav-btn.rfm-is-open {
	background: none;
	font-weight: 700;
}

/* Inline images/HTML inside menu labels */
.rfm-nav-btn img,
.rfm-nav-link img,
.rfm-drop-link img,
.rfm-panel-link img {
	display: inline-block;
	vertical-align: middle;
	max-height: 1.4em;
	width: auto;
}

.rfm-chevron {
	transition: transform 0.22s;
	flex-shrink: 0;
}
.rfm-nav-btn.rfm-is-open .rfm-chevron {
	transform: rotate(180deg);
}

/* ── Hamburger Button ──────────────────────────────────── */
.rfm-hamburger {
	background: none;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin: 0 4px;
	padding: 0;
	line-height: 0;
}
.rfm-hamburger:focus {
	background: transparent;
	outline: none;
}

.rfm-hamburger-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	transition: opacity 0.2s, transform 0.2s;
}
.rfm-hamburger-icon svg,
.rfm-hamburger-icon i {
	display: block;
}
.rfm-icon-close { display: none; }
.rfm-hamburger.rfm-is-open .rfm-icon-open  { display: none; }
.rfm-hamburger.rfm-is-open .rfm-icon-close { display: flex; }

/* ── Dark Panel ────────────────────────────────────────── */
.rfm-panel {
	position: absolute;
	top: -16px;
	left: 0;
	width: 100%;
	z-index: 200;
	background: #2b2b2b;
	border-radius: 20px;
	overflow: hidden;
	opacity: 0;
	transform: translateY(-12px);
	pointer-events: none;
	transition:
		opacity 0.3s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.rfm-panel.rfm-is-open {
	opacity: 1;
	transform: translateY(0);
	pointer-events: all;
}

/* ── Panel Content Bodies ──────────────────────────────── */
.rfm-drop-body {
	display: none;
	flex-direction: column;
}
.rfm-drop-body.rfm-is-active { display: flex; }

.rfm-drop-body::before {
	content: '';
	display: block;
	height: 70px;
}

/* ── Dropdown Links ────────────────────────────────────── */
.rfm-drop-link {
	display: block;
	font-size: clamp(20px, 3.2vw, 26px);
	font-weight: 600;
	color: #fff;
	text-decoration: none;
	padding: 10px 24px;
	border-radius: 10px;
	margin: 0 12px;
	transition: background 0.16s, color 0.16s;
}
.rfm-drop-link:hover {
	background: #fff;
	color: #1a1a1a;
}

/* ── Hamburger Body Layout ─────────────────────────────── */
.rfm-hamburger-inner {
	display: flex;
	justify-content: space-between;
	padding: 35px 28px 20px;
	gap: 20px;
}

.rfm-panel-links {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.rfm-panel-link {
	font-size: clamp(26px, 4.5vw, 34px);
	font-weight: 700;
	color: #fff;
	text-decoration: none;
	line-height: 1.25;
	transition: opacity 0.18s;
}
.rfm-panel-link:hover { opacity: 0.6; }

.rfm-panel-social {
	display: flex;
	flex-direction: column;
	gap: 4px;
	align-items: flex-end;
}
.rfm-panel-social-link {
	font-size: 13px;
	color: rgba(255,255,255,0.6);
	text-decoration: none;
	transition: color 0.18s;
	overflow: hidden;
}
.rfm-panel-social-link:hover { color: #fff; }

/* Social icon slide-up on hover */
.rfm-panel-social-link .menu-social_icon {
	display: inline-block;
	transform: translateY(100%);
	opacity: 0;
	transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
				opacity 0.3s cubic-bezier(0.22, 1, 0.36, 1);
	vertical-align: middle;
	margin-right: 4px;
}
.rfm-panel-social-link:hover .menu-social_icon {
	transform: translateY(0);
	opacity: 1;
}
.rfm-panel-social-link .menu-social_icon img,
.rfm-panel-social-link .menu-social_icon svg {
	display: inline-block;
	vertical-align: middle;
	width: 1em;
	height: 1em;
}

/* ── Panel Footer ──────────────────────────────────────── */
.rfm-panel-footer {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding: 14px 28px 18px;
	border-top: 1px solid rgba(255,255,255,0.08);
	font-size: 12px;
	color: rgba(255,255,255,0.38);
	gap: 12px;
	margin-top: 8px;
}
.rfm-panel-footer span:first-child { max-width: 200px; line-height: 1.4; }
.rfm-panel-footer span:last-child  { white-space: nowrap; }

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 520px) {
	.rfm-navbar { padding: 5px 7px; gap: 0; }
	.rfm-nav-btn, .rfm-nav-link { font-size: 12px; padding: 6px 9px; }
	.rfm-hamburger-icon { width: 40px; height: 31px; }
	.rfm-hamburger-inner { flex-direction: column; padding: 0 20px 16px; }
	.rfm-panel-social { align-items: flex-start; }
}
