@charset "UTF-8";

/* 파일 목적: 모바일 화면 전용 오버라이드를 관리한다. */

/* ============================================
   모바일 기본 구조
   ============================================ */

@media (max-width: 600px) {

	/* ============================================
   모바일 전역 변수
   ============================================ */

	/* ----- 모바일 변수 ----- */
	:root {
		--mobile-padding: 24px;
		--mobile-gap: 20px;
		--header-height: 60px;
	}

	html,
	body {
		width: 100% !important;
		min-width: 0 !important;
		max-width: 100vw !important;
		overflow-x: hidden !important;
		font-size: var(--font-base-plus);
		margin: 0 !important;
		padding: 0 !important;
	}

	body {
		padding-top: var(--space-section-sm) !important;
	}

	.container {
		width: 100% !important;
		min-width: 0 !important;
		max-width: none !important;
		padding: 0 var(--space-md) !important;
		margin: 0 !important;
	}

	.C-partners .container {
		padding: 0 var(--space-sm-plus) !important;
	}

	.L-section-border::before {
		top: -8px;
	}

	.L-section-header,
	.L-section-sub-header {
		padding: 0 var(--space-md);
		margin-bottom: var(--space-xl-compact);
		text-align: center;
	}

	.L-section-title {
		font-size: var(--font-2xl-sm) !important;
		line-height: 1.3 !important;
		margin-bottom: var(--space-sm-plus) !important;
		word-break: keep-all;
	}

	.L-section-sub {
		display: block;
		font-size: var(--font-base) !important;
		margin-top: var(--space-tight-plus);
		opacity: 0.8;
		font-weight: 500;
	}

	.L-section-desc,
	.L-section-sub-desc {
		font-size: var(--font-base) !important;
		line-height: 1.6 !important;
		color: var(--text-muted);
		word-break: keep-all;
	}

	.L-section-desc br,
	.L-section-sub-desc br {
		display: none;
	}

	/* ============================================
   모바일 헤더
   ============================================ */

	/* ----- 고정 헤더 ----- */
	header#header {
		position: fixed !important;
		top: 0 !important;
		left: 0 !important;
		width: 100% !important;
		min-width: 0 !important;
		height: var(--header-height) !important;
		min-height: var(--header-height) !important;
		margin: 0 !important;
		z-index: var(--z-top-fixed);
		background: var(--ui-surface-card);
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		border-bottom: 1px solid var(--shadow-md);
		box-shadow: none;
		border-radius: 0 !important;
		box-shadow: var(--shadow-md);
	}

	header#header .container,
	.navbar-wrapper {
		height: var(--header-height) !important;
		min-height: var(--header-height) !important;
		border-radius: 0 !important;
	}

	/* ============================================
   모바일 내비게이션
   ============================================ */

	.C-nav {
		width: 100% !important;
		max-width: 100% !important;
		padding: 0 !important;
		margin: 0 auto !important;
		display: flex;
		align-items: center;
		justify-content: space-between;
		height: var(--header-height) !important;
		min-height: var(--header-height) !important;
		border-radius: 0 !important;
		border: none;
		border-bottom: 1px solid var(--shadow-md);
	}

	.stuck .C-nav {
		background: var(--ui-surface-card);
		border: none;
		box-shadow: none;
		border-bottom: 1px solid var(--shadow-md);
	}

	.C-nav-indicator {
		border: none;
		border-radius: 0;
	}

	.C-nav-brand {
		font-size: var(--font-lg-sm);
		display: flex;
		align-items: center;
		font-weight: 700;
		color: var(--text-display);
		text-decoration: none;
		gap: var(--gap-sm);
	}

	.C-nav-brand-icon {
		font-size: var(--font-xl);
		color: var(--brand-primary);
	}

	.C-nav-toggle {
		display: flex !important;
		width: 44px;
		height: 44px;
		padding: 0;
		align-items: center;
		justify-content: center;
		font-size: var(--font-2xl-sm);
		margin-right: -10px;
		background: none;
		border: none;
		cursor: pointer;
		color: var(--text-display);
		z-index: var(--z-popover);
	}

	.C-nav-links {
		position: fixed !important;
		top: 0 !important;
		right: -100% !important;
		width: 250px !important;
		height: 100vh !important;
		height: 100dvh !important;
		background: var(--ui-surface-card) !important;
		z-index: var(--z-drawer) !important;
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		padding: var(--space-section-sm) 0 var(--space-2xl-compact) !important;
		box-shadow: -4px 0 20px var(--shadow-md) !important;
		transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
		overflow-y: auto !important;
		gap: 0 !important;
		border-radius: 0 !important;
		margin: 0 !important;
		border: none !important;
	}

	.C-nav-links.open {
		right: -20px !important;
	}

	.C-nav-links a {
		padding: var(--space-sm) var(--space-xl-compact) !important;
		border-bottom: 1px solid var(--color-bg-muted) !important;
		border-radius: 0 !important;
		width: 100% !important;
		font-size: var(--font-base-plus) !important;
		color: var(--text-body) !important;
		background: transparent;
		justify-content: flex-start !important;
		height: auto !important;
		text-align: left !important;
		display: flex !important;
		align-items: center !important;
		gap: var(--gap-sm) !important;
	}

	.C-nav-links a:hover,
	.C-nav-links a.active {
		background: var(--color-bg-soft) !important;
		color: var(--brand-primary) !important;
		border-radius: 0 !important;
		font-weight: 600 !important;
	}

	.C-nav-links a.active {
		background: hsl(348 100.0% 98.0%) !important;
		border-right: 4px solid var(--brand-primary) !important;
		border-bottom: 1px solid var(--color-bg-muted) !important;
	}

	.C-nav-links .mobile-only {
		display: flex !important;
	}

	.C-nav-links .C-nav-icon {
		display: inline-block !important;
		font-size: var(--font-lg) !important;
		color: var(--color-slate-muted) !important;
		margin-right: var(--space-sm-compact) !important;
	}

	.C-nav-close,
	.C-nav-overlay {
		display: none;
	}

	/* ============================================
   모바일 히어로
   ============================================ */

	/* ----- 모바일 히어로 ----- */
	.L-hero {
		padding: var(--space-2xl-compact) 0 0;
		min-height: auto;
		text-align: center;
	}

	.L-hero-wrap {
		padding: 0 var(--space-md);
	}

	.L-hero-title {
		font-size: var(--font-3xl) !important;
		line-height: 1.25 !important;
		margin-bottom: var(--space-sm);
	}

	.L-hero-desc {
		font-size: var(--font-base-plus) !important;
		padding: 0 var(--space-sm-plus);
		margin-bottom: var(--space-xl-compact);
	}

	.L-hero-actions {
		flex-direction: column;
		gap: var(--gap-sm);
		padding: 0 var(--space-lg-compact);
	}

	.C-button--main,
	.C-button--sub {
		width: 100%;
		justify-content: center;
		padding: var(--space-sm);
		font-size: var(--font-base-plus);
	}

	.L-hero-marquee {
		margin: var(--space-lg-compact) 0;
		padding: var(--space-sm-plus) 0;
	}

	.L-hero-marquee span {
		font-size: var(--font-base-sm);
		padding: 0 var(--space-sm);
	}

	.L-hero-grid {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: nowrap !important;
		overflow-x: auto !important;
		scroll-snap-type: x mandatory;
		gap: var(--gap-lg) !important;
		padding: 0 var(--space-md) var(--space-lg-compact) !important;
		margin: 0 -24px !important;
		margin-top: var(--space-3xl-compact);
		width: calc(100% + var(--mobile-padding) * 2) !important;
		scrollbar-width: none;
	}

	.L-hero-grid::-webkit-scrollbar {
		display: none;
	}

	.L-hero-grid::after {
		content: "";
		min-width: var(--mobile-padding);
		height: 1px;
	}

	.C-hero-card {
		min-width: 100% !important;
		scroll-snap-align: center;
		margin: 0 !important;
		width: 100% !important;
		max-width: none !important;
		box-shadow: 0 4px 12px var(--shadow-sm) !important;
	}

	.C-hero-card:hover {
		transform: none !important;
		box-shadow: 0 4px 12px var(--shadow-sm) !important;
	}

	.C-hero-card:hover .C-hero-card-frame img {
		transform: none !important;
	}

	.L-hero-pagination {
		display: flex !important;
		justify-content: center;
		padding: var(--space-sm-plus) 0 var(--space-3xl-compact) 0;
		gap: var(--gap-sm);
	}

	.L-hero-dot {
		width: 8px;
		height: 8px;
		border-radius: var(--radius-circle);
		background: var(--color-border-muted);
		transition: var(--transition-all-fast);
	}

	.L-hero-dot.active {
		width: 24px;
		border-radius: var(--radius-badge);
		background: var(--brand-accent);
	}

	.C-partners {
		margin-top: 0;
	}

	.C-partners-grid {
		display: grid;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 0 !important;
		grid-auto-rows: 75px;
	}

	.grid-list-row-2 {
		display: flex !important;
		flex-direction: column !important;
		gap: var(--gap-md) !important;
	}

	/* ============================================
   모바일 카드 타입 1
   ============================================ */

	.C-card.C-card--v1 {
		flex-direction: column !important;
		align-items: flex-start !important;
		text-align: left !important;
		padding: var(--grid-card-pad-mobile) !important;
		gap: var(--gap-md) !important;
	}

	.C-card.C-card--v1:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	.C-card-icon {
		width: 50px !important;
		height: 50px !important;
		font-size: var(--font-xl) !important;
		flex-shrink: 0;
		margin: 0 !important;
	}

	.C-card-content {
		align-items: flex-start !important;
	}

	.C-card-title {
		font-size: var(--font-md-plus) !important;
		margin-bottom: var(--space-tight-plus) !important;
		text-align: left !important;
	}

	.C-card-text {
		font-size: var(--font-base-sm) !important;
		padding: 0 !important;
		line-height: 1.5;
	}

	/* ============================================
   모바일 카드 타입 2
   ============================================ */

	.C-card.C-card--v2 {
		padding: var(--grid-card-pad-mobile) !important;
	}

	.C-card.C-card--v2:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	.C-card--v2-top-icon {
		top: 20px !important;
		right: 20px !important;
	}

	.C-card--v2-header {
		flex-direction: row !important;
		align-items: flex-start !important;
		gap: var(--gap-md) !important;
		text-align: left !important;
	}

	.C-card--v2-avatar {
		width: 60px !important;
		height: 60px !important;
		margin: 0 !important;
	}

	.C-card--v2-info {
		align-items: flex-start !important;
	}

	.C-card--v2-info h4 {
		font-size: var(--font-md-plus) !important;
	}

	.email-full {
		display: none;
	}

	.email-short {
		display: inline;
	}

	.C-intro-brand {
		padding: 0 var(--space-md);
		margin-top: var(--space-2xl-compact);
	}

	.C-intro-brand h3 {
		font-size: var(--font-base) !important;
		line-height: 1.5;
		margin-bottom: var(--space-lg-compact);
		word-break: keep-all;
	}

	.C-intro-brand-logos {
		display: flex !important;
		flex-wrap: wrap !important;
		gap: var(--gap-xs) !important;
		justify-content: center !important;
		padding: 0 var(--space-sm-plus) !important;
	}

	.C-intro-brand-logos li {
		font-size: var(--font-xl);
		color: var(--color-slate-muted);
	}

	.C-intro-brand-logos i {
		opacity: 0.6 !important;
	}

	.ranking-list {
		gap: var(--gap-md) !important;
		padding: 0 !important;
	}

	.C-card.C-card--rank {
		display: grid !important;
		grid-template-columns: 30px 1fr auto !important;
		grid-template-areas:
			"rank brand brand"
			"rank content content"
			"rank footer action";
		position: relative !important;
		margin-bottom: 0 !important;
		border: 1px solid var(--ui-border-subtle) !important;
		border-radius: var(--radius-surface) !important;
		overflow: hidden !important;
		background: var(--ui-surface-card) !important;
		box-shadow: none;
		padding: var(--space-sm-plus) !important;
		gap: 0 !important;
	}

	.C-card--rank-num {
		grid-area: rank;
		position: static !important;
		width: 100% !important;
		height: 100% !important;
		display: flex !important;
		align-items: center;
		justify-content: center;
		font-family: var(--font-display);
		font-weight: 800;
		font-size: var(--font-lg) !important;
		color: var(--brand-primary) !important;
		font-style: italic;
		border-radius: 0 !important;
		box-shadow: none !important;
	}

	.C-card--rank-brand {
		grid-area: brand;
		padding: var(--space-sm-compact) var(--space-sm) var(--space-2xs) !important;
		display: flex !important;
		flex-direction: row !important;
		align-items: center !important;
		gap: var(--gap-sm) !important;
		border: none !important;
		background: var(--ui-surface-card);
		justify-content: flex-start !important;
	}

	.ranking-badge-group {
		display: flex;
		gap: var(--gap-xs);
		margin: 0 !important;
	}

	.ranking-badge {
		font-size: var(--font-xs) !important;
		padding: var(--space-micro) var(--space-tight-plus);
		border-radius: var(--radius-badge);
		background: var(--color-bg-muted);
		color: var(--text-muted);
	}

	.C-card--rank-name {
		font-size: var(--font-md-plus) !important;
		font-weight: 800;
		color: var(--brand-dark);
		margin: 0 !important;
		order: -1;
	}

	.C-card--rank-bonus {
		grid-area: content;
		margin: 0 !important;
		padding: var(--space-2xs) var(--space-sm) 0 !important;
		background: transparent !important;
		border: none !important;
		text-align: left !important;
		display: flex !important;
		flex-direction: row !important;
		gap: var(--gap-sm) !important;
		align-items: baseline !important;
		border-radius: 0;
		justify-content: flex-start !important;
	}

	.C-card--rank-bonus-label {
		display: none;
	}

	.C-card--rank-bonus-main {
		font-size: var(--font-base-sm) !important;
		font-weight: 800 !important;
		color: var(--brand-accent);
	}

	.C-card--rank-bonus-sub {
		font-size: var(--font-sm) !important;
		color: var(--color-slate-muted);
		font-weight: 500;
	}

	.C-card--rank-action {
		grid-area: action;
		position: static !important;
		transform: none !important;
		padding: var(--space-tight) var(--space-sm) var(--space-tight) 0 !important;
		display: flex !important;
		align-items: center;
		justify-content: flex-end;
		height: 100%;
		width: auto !important;
	}

	.ranking-btn {
		width: auto !important;
		padding: var(--space-tight-plus) var(--space-field-y) !important;
		font-size: var(--font-sm) !important;
		height: 32px !important;
		font-weight: 700;
		border-radius: 100px !important;
		box-shadow: 0 4px 10px var(--glow-accent) !important;
		background: linear-gradient(90deg, var(--brand-primary-color) 0%, hsl(340 100.0% 62.5%) 100%) !important;
		color: var(--ui-surface-card) !important;
		border: none !important;
	}

	.ranking-btn i {
		display: none !important;
	}

	.C-card--rank-safety {
		grid-area: footer;
		padding: var(--space-tight) var(--space-sm) !important;
		border-left: none !important;
		display: flex !important;
		justify-content: flex-start !important;
		align-items: left !important;
		gap: var(--gap-sm) !important;
		height: 100%;
	}

	.ranking-safety-item {
		display: none !important;
	}

	.C-card--rank-stars {
		width: auto !important;
		margin: 0 !important;
		font-size: var(--font-base-sm);
		color: var(--accent-star);
	}

	.C-card--rank-desc {
		display: none !important;
	}

	.C-card--rank-footer {
		margin-top: var(--space-sm-plus);
		gap: var(--gap-sm);
		align-items: flex-start;
	}

	.C-card--rank-footer .notice-text {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--gap-xs);
	}

	.C-card--rank-footer .update-date {
		margin-left: 0;
		text-align: left;
		display: block;
	}

	.C-card.C-card--v3 {
		padding: var(--grid-card-pad-mobile) !important;
	}

	.C-card.C-card--v3:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	.C-card--v3-step-badge {
		font-size: var(--font-sm) !important;
	}

	.C-card--v3-title {
		font-size: var(--font-lg) !important;
		margin: var(--space-sm-plus) 0 !important;
	}

	.C-card.C-card--v4 {
		padding: 0 !important;
		border-radius: var(--radius-md) !important;
		overflow: hidden;
		box-shadow: none;
		gap: 0;
	}

	.C-card--v4-top {
		padding: var(--space-lg-compact) !important;
		flex-direction: row !important;
		align-items: center !important;
		text-align: left !important;
		gap: var(--gap-md) !important;
	}

	.C-card--v4-icon {
		width: 48px !important;
		height: 48px !important;
		font-size: var(--font-xl-sm) !important;
		margin: 0 !important;
	}

	.C-card--v4-content {
		align-items: flex-start !important;
	}

	.C-card--v4-title {
		font-size: var(--font-md-plus) !important;
		margin-bottom: var(--space-2xs) !important;
	}

	.C-card--v4-text {
		font-size: var(--font-base-sm) !important;
		line-height: 1.5 !important;
		opacity: 0.8 !important;
	}

	.C-card--v4-list {
		padding: var(--space-lg-compact) !important;
		gap: var(--gap-md) !important;
	}

	.C-card--v4-list li {
		padding: var(--space-sm) !important;
	}

	.C-card--v4-short {
		min-height: auto !important;
	}

	.C-card--v4-short .C-card--v4-top {
		padding: var(--space-lg-compact) !important;
		gap: var(--gap-sm) !important;
	}

	.grid-list-row-3 {
		display: flex !important;
		flex-direction: column !important;
		gap: var(--gap-md) !important;
		padding: 0 !important;
	}

	.C-card.C-card--v5 {
		padding: 0 !important;
		border-radius: var(--radius-md) !important;
		overflow: hidden;
		border: 1px solid var(--ui-border-subtle);
	}

	.C-card--v5-media {
		height: 160px !important;
	}

	.C-card--v5-content {
		padding: var(--space-lg-compact) !important;
		background-color: var(--ui-surface-card);
	}

	.C-card--v5-title {
		font-size: var(--font-lg) !important;
	}

	.strategy-grid {
		grid-template-columns: 1fr !important;
		gap: var(--gap-md) !important;
	}

	.strategy-category-block {
		padding: var(--space-lg-compact);
		margin-bottom: var(--space-lg-compact);
	}

	.strategy-cat-header {
		flex-direction: row;
		align-items: center;
		gap: var(--gap-sm);
		margin-bottom: var(--space-lg-compact);
		text-align: left;
	}

	.strategy-cat-icon {
		width: 50px;
		height: 50px;
		font-size: var(--font-xl);
		flex-shrink: 0;
	}

	.strategy-cat-text h3 {
		font-size: var(--font-lg);
		margin-bottom: var(--space-2xs);
	}

	.strategy-cat-text p {
		font-size: var(--font-sm-plus);
		opacity: 0.8;
	}

	.C-card--trend-grid {
		display: flex !important;
		flex-direction: column !important;
		gap: var(--gap-md) !important;
	}

	.C-card.C-card--trend {
		flex-direction: column !important;
		align-items: flex-start !important;
		padding: var(--grid-card-pad-mobile) !important;
	}

	.C-card.C-card--trend:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	.C-card--trend-media {
		width: 100% !important;
		height: 180px !important;
	}

	.C-card--trend-content {
		padding: var(--space-lg-compact) !important;
		width: 100% !important;
	}

	.C-card--trend-tags {
		gap: var(--gap-xs) !important;
	}

	.C-card--trend-tag {
		font-size: var(--font-sm) !important;
		padding: var(--space-2xs) var(--space-xs) !important;
	}

	.caution-section {
		padding-top: var(--space-section-sm) !important;
	}

	.caution-safety-notice {
		margin-top: var(--space-lg-compact);
		padding: var(--space-md) !important;
	}

	.caution-safety-title {
		font-size: var(--font-lg) !important;
	}

	.faq-grid {
		grid-template-columns: 1fr !important;
		gap: var(--gap-md) !important;
		padding: 0;
	}

	.faq-answer {
		font-size: var(--font-base-sm) !important;
		line-height: 1.6 !important;
	}

	.C-card--conclusion-grid {
		display: flex !important;
		flex-direction: column !important;
		gap: var(--gap-md) !important;
		padding: 0 !important;
	}

	.C-card.C-card--conclusion {
		padding: var(--grid-card-pad-mobile) !important;
		border-radius: var(--radius-md) !important;
	}

	.C-card.C-card--conclusion:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	.C-card--conclusion-icon-box {
		width: 48px !important;
		height: 48px !important;
		font-size: var(--font-xl) !important;
	}

	.C-card--conclusion-info strong {
		font-size: var(--font-md-plus) !important;
	}

	.C-card--conclusion-desc {
		font-size: var(--font-base-sm) !important;
		line-height: 1.5 !important;
	}

	/* ----- GRID_CSS: strategy 모바일 ----- */
	.C-card--strategy-grid {
		grid-template-columns: 1fr !important;
		gap: var(--gap-md) !important;
	}

	.C-card.C-card--strategy {
		padding: var(--grid-card-pad-mobile) !important;
	}

	.C-card.C-card--strategy:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	/* ----- GRID_CSS: faq 모바일 ----- */
	.C-faq-grid {
		grid-template-columns: 1fr !important;
		gap: var(--gap-md) !important;
	}

	.C-faq-item {
		padding: var(--grid-card-pad-mobile) !important;
	}

	.C-faq-item:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	footer {
		text-align: left;
		padding-bottom: var(--space-lg-compact);
	}

	.C-footer-grid {
		grid-template-columns: repeat(3, 1fr) !important;
		gap: var(--gap-md) !important;
		padding: 0 var(--space-lg-compact);
	}

	.C-footer-grid>div:first-child {
		grid-column: 1 / -1;
		margin-bottom: var(--space-sm-plus);
	}

	.C-footer-brand {
		font-size: var(--font-lg) !important;
		margin-bottom: var(--space-sm-plus) !important;
	}

	.C-footer-desc {
		font-size: var(--font-base-sm) !important;
		line-height: 1.5 !important;
		word-break: keep-all;
	}

	.C-footer-nav {
		margin-bottom: 0 !important;
	}

	.C-footer-nav h4.C-footer-title {
		font-size: var(--font-sm-plus) !important;
		margin-bottom: var(--space-sm-compact) !important;
		color: var(--text-footer-head) !important;
	}

	.footer-links {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--gap-sm);
	}

	.footer-links a {
		padding: var(--space-xs) 0;
		font-size: var(--font-base-sm);
	}
}

/* ============================================
   플로팅 메뉴
   ============================================ */

/* ----- 플로팅 메뉴 ----- */
.C-fab {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: var(--z-top-fixed);
	display: none;

}

@media (max-width: 768px) {

	.C-fab {
		display: block !important;
		display: block;
	}
}

.C-fab-trigger {
	width: 56px;
	height: 56px;
	border-radius: var(--radius-circle);
	background: var(--brand-accent, var(--accent-primary));
	box-shadow: 0 4px 12px hsl(0 0.0% 0.0% / 0.3);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: var(--font-xl);
	position: relative;
	transition: opacity 0.3s ease;
	-webkit-tap-highlight-color: transparent;
}

.C-fab-trigger:active {
	transform: scale(0.95);
}

.C-fab-trigger.active {
	background: var(--brand-accent, var(--accent-primary));
	transform: rotate(90deg);
}

.C-fab.scrolling .C-fab-trigger {
	opacity: 0.5;
	pointer-events: none;

}

.C-fab-progress {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	transform: rotate(-90deg);
	opacity: 0.3;
}

.progress-ring__circle {
	stroke-dasharray: 163;

	stroke-dashoffset: 163;

	transition: stroke-dashoffset 0.35s;
	transform-origin: 50% 50%;
}

.C-fab-menu {
	position: absolute;
	bottom: 72px;

	right: 0;
	background: white;
	border-radius: var(--radius-md);
	box-shadow: 0 8px 32px var(--shadow-lg);
	padding: var(--space-xs);
	width: max-content;
	min-width: 180px;
	display: flex;
	flex-direction: column;
	gap: var(--gap-xs);
	opacity: 0;
	transform: translateY(20px) scale(0.95);
	transform-origin: bottom right;
	pointer-events: none;
	transition: opacity 0.3s ease-out;
	border: 1px solid var(--ui-border-subtle);
}

.C-fab.active .C-fab-menu {
	opacity: 1;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

.C-fab-menu-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-xs) var(--space-sm-compact);
	border-bottom: 1px solid var(--color-bg-muted);
	margin-bottom: var(--space-2xs);
}

.C-fab-menu-title {
	font-size: var(--font-base-sm);
	font-weight: 600;
	color: var(--text-muted);
}

.C-fab-close {
	background: none;
	border: none;
	color: var(--color-slate-muted);
	cursor: pointer;
	font-size: var(--font-md-plus);
	padding: var(--space-2xs);
}

.C-fab-item {
	display: flex;
	align-items: center;
	gap: var(--gap-sm);
	padding: var(--space-tight-plus) var(--space-xs);
	border-radius: var(--radius-sm);
	color: var(--text-body);
	text-decoration: none;
	font-size: var(--font-sm-plus);
	font-weight: 400;
	transition: background-color 0.2s;
}

.C-fab-item i {
	font-size: var(--font-base-sm);
	color: var(--color-slate-muted);
	transition: color 0.3s ease;
}

.C-fab-item:active,
.C-fab-item:hover {
	background: var(--color-bg-soft);
	color: var(--brand-accent, var(--accent-primary));
}

.C-fab-item:active i,
.C-fab-item:hover i {
	color: var(--brand-accent, var(--accent-primary));
}

.C-fab-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: hsl(0 0.0% 0.0% / 0.4);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
	z-index: var(--z-background);

	backdrop-filter: blur(2px);
}

.C-fab.active .C-fab-overlay {
	opacity: 1;
	pointer-events: auto;
}