/**
 * Telkari Design 1: Orbit
 *
 * Quarter circle trigger in a corner with icons fanning out
 * in an arc on hover or click.
 *
 * @package Telkari
 */

.telkari-container.telkari-design-1 {
	position: fixed;
	z-index: 9999;
	--telkari-design-1-icon-size: var(--telkari-icon-size, 2.5rem);
	--telkari-design-1-icon-spacing: var(--telkari-icon-spacing, 0.5rem);
}

.telkari-design-1 .telkari-design-shell {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

/* Positions */
.telkari-design-1.telkari-position-bottom-right {
	bottom: 0;
	right: 0;
}

.telkari-design-1.telkari-position-bottom-left {
	bottom: 0;
	left: 0;
}

.telkari-design-1.telkari-position-bottom-right .telkari-design-shell {
	align-items: flex-end;
}

.telkari-design-1.telkari-position-bottom-left .telkari-design-shell {
	align-items: flex-start;
}

.telkari-design-1:not(.telkari-has-socials) .telkari-design-shell {
	padding: 1rem;
}

.telkari-design-1 .telkari-social-group {
	position: relative;
	width: var(--telkari-trigger-size, 3.75rem);
	height: var(--telkari-trigger-size, 3.75rem);
}

.telkari-design-1 .telkari-cta-wrapper {
	flex-direction: column;
	padding: 0;
}

.telkari-design-1.telkari-position-bottom-right .telkari-cta-wrapper {
	align-items: flex-end;
}

.telkari-design-1.telkari-position-bottom-left .telkari-cta-wrapper {
	align-items: flex-start;
}

.telkari-design-1 .telkari-cta-link {
	min-width: 9.5rem;
}

/* Trigger button - quarter circle */
.telkari-design-1 .telkari-trigger {
	width: var(--telkari-trigger-size, 3.75rem);
	height: var(--telkari-trigger-size, 3.75rem);
	background-color: var(--telkari-trigger-bg, #1e293b);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--telkari-trigger-fg, #fff);
	position: relative;
	z-index: 2;
	padding: 0;
	transition: opacity 0.2s;
}

.telkari-design-1 .telkari-trigger:hover {
	opacity: 0.85;
}

.telkari-design-1 .telkari-trigger-icon {
	width: 40%;
	height: 40%;
	transition: transform 0.3s;
	position: absolute;
	top: 40%;
}

.telkari-design-1.telkari-position-bottom-left .telkari-trigger-icon {
    left: 20%;
}

.telkari-design-1.telkari-position-bottom-right .telkari-trigger-icon {
    right: 20%;
}

.telkari-design-1.telkari-open .telkari-trigger-icon {
	transform: rotate(45deg);
}

/* Quarter circle shape per position */
.telkari-design-1.telkari-position-bottom-right .telkari-trigger {
	border-radius: 5rem 0 0 0;
	margin-left: auto;
}

.telkari-design-1.telkari-position-bottom-left .telkari-trigger {
	border-radius: 0 5rem 0 0;
	margin-right: auto;
}

/* Icons wrapper */
.telkari-design-1 .telkari-icons-wrapper {
	position: absolute;
	bottom: 0;
	width: 0;
	height: 0;
}

.telkari-design-1.telkari-position-bottom-right .telkari-icons-wrapper {
	right: 0;
}

.telkari-design-1.telkari-position-bottom-left .telkari-icons-wrapper {
	left: 0;
}

/* Icon links - start at trigger corner, fly out to arc positions */
.telkari-design-1 .telkari-icon-link {
	--telkari-arc-radius-base: calc((var(--telkari-design-1-icon-size) + var(--telkari-design-1-icon-spacing)) * var(--telkari-item-count) * 0.7 + var(--telkari-design-1-icon-size));
	--telkari-arc-radius: min(var(--telkari-arc-radius-base), calc(100vw - var(--telkari-trigger-size, 3.75rem) - 1rem), calc(100vh - var(--telkari-trigger-size, 3.75rem) - 1rem));
	--telkari-angle-pad: calc(1rem + var(--telkari-design-1-icon-size) / 2);
	--telkari-angle-min: calc(atan2(var(--telkari-angle-pad), var(--telkari-arc-radius)));
	--telkari-angle-max: calc(90deg - var(--telkari-angle-min));
	--telkari-angle: calc(var(--telkari-angle-min) + (var(--telkari-angle-max) - var(--telkari-angle-min)) * var(--telkari-item-index) / max(var(--telkari-item-count) - 1, 1));
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--telkari-design-1-icon-size);
	height: var(--telkari-design-1-icon-size);
	background-color: var(--telkari-bg, #1e293b);
	color: var(--telkari-fg, #fff);
	text-decoration: none;
	opacity: 0;
	transform: scale(0.2);
	transition: opacity 0.35s ease, transform 0.35s ease, box-shadow 0.2s ease;
	transition-delay: calc((var(--telkari-item-count) - 1 - var(--telkari-item-index)) * 0.045s);
}

.telkari-design-1.telkari-open .telkari-icon-link:hover {
	box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.3);
	transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.35s ease;
	transition-delay: 0s;
}

/* Closed state: all icons stacked at the corner (behind trigger) */
.telkari-design-1.telkari-position-bottom-right .telkari-icon-link {
	bottom: 0;
	right: 0;
}

.telkari-design-1.telkari-position-bottom-left .telkari-icon-link {
	bottom: 0;
	left: 0;
}

/* Open state: icons fly from corner to arc positions while scaling up */
.telkari-design-1.telkari-position-bottom-right.telkari-open .telkari-icon-link {
	opacity: 1;
	transform: translate(
			calc(-1 * cos(var(--telkari-angle)) * var(--telkari-arc-radius) + var(--telkari-design-1-icon-size) / 2),
			calc(-1 * sin(var(--telkari-angle)) * var(--telkari-arc-radius) + var(--telkari-design-1-icon-size) / 2)
		)
		scale(1);
}

.telkari-design-1.telkari-position-bottom-left.telkari-open .telkari-icon-link {
	opacity: 1;
	transform: translate(
			calc(cos(var(--telkari-angle)) * var(--telkari-arc-radius) - var(--telkari-design-1-icon-size) / 2),
			calc(-1 * sin(var(--telkari-angle)) * var(--telkari-arc-radius) + var(--telkari-design-1-icon-size) / 2)
		)
		scale(1);
}

/* Hover: scale in place without shifting position */
.telkari-design-1.telkari-position-bottom-right.telkari-open .telkari-icon-link:hover {
	transform: translate(
			calc(-1 * cos(var(--telkari-angle)) * var(--telkari-arc-radius) + var(--telkari-design-1-icon-size) / 2),
			calc(-1 * sin(var(--telkari-angle)) * var(--telkari-arc-radius) + var(--telkari-design-1-icon-size) / 2)
		)
		scale(1.15);
}

.telkari-design-1.telkari-position-bottom-left.telkari-open .telkari-icon-link:hover {
	transform: translate(
			calc(cos(var(--telkari-angle)) * var(--telkari-arc-radius) - var(--telkari-design-1-icon-size) / 2),
			calc(-1 * sin(var(--telkari-angle)) * var(--telkari-arc-radius) + var(--telkari-design-1-icon-size) / 2)
		)
		scale(1.15);
}

/* Forward stagger on open, reverse stagger on close */
.telkari-design-1.telkari-open .telkari-icon-link {
	transition-delay: calc(var(--telkari-item-index) * 0.045s);
}

/* Icon style: rounded */
.telkari-design-1.telkari-style-rounded .telkari-icon-link {
	border-radius: 50%;
}

/* Icon style: square */
.telkari-design-1.telkari-style-square .telkari-icon-link {
	border-radius: 0.125rem;
}

/* SVG icon sizing */
.telkari-design-1 .telkari-icon {
	width: 55%;
	height: 55%;
	fill: currentColor;
}

/* Tooltips */
.telkari-design-1.telkari-has-tooltips .telkari-icon-link {
	position: absolute;
}

.telkari-design-1.telkari-has-tooltips .telkari-icon-link::after {
	content: attr(title);
	position: absolute;
	white-space: nowrap;
	padding: 0.25rem 0.5rem;
	background-color: #1e293b;
	color: #fff;
	font-size: 0.75rem;
	line-height: 1.4;
	border-radius: 0.125rem;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.15s;
	top: 50%;
	transform: translateY(-50%);
}

.telkari-design-1.telkari-has-tooltips .telkari-icon-link:hover::after {
	opacity: 1;
}

.telkari-design-1.telkari-position-bottom-right.telkari-has-tooltips .telkari-icon-link::after {
	right: calc(100% + 0.5rem);
}

.telkari-design-1.telkari-position-bottom-left.telkari-has-tooltips .telkari-icon-link::after {
	left: calc(100% + 0.5rem);
}

@media (max-width: 48rem) {
	.telkari-container.telkari-design-1 {
		--telkari-design-1-icon-size: var(--telkari-mobile-icon-size);
		--telkari-design-1-icon-spacing: var(--telkari-mobile-icon-spacing);
	}

	.telkari-design-1 .telkari-design-shell {
		gap: var(--telkari-mobile-group-gap);
	}

	.telkari-design-1:not(.telkari-has-socials) .telkari-design-shell {
		padding: 0.75rem;
	}

	.telkari-design-1 .telkari-cta-wrapper {
		align-items: stretch;
		gap: var(--telkari-mobile-cta-spacing);
		padding: 0 0.375rem 0.375rem;
		max-width: calc(100vw - 1rem);
		width: var(--telkari-mobile-cta-stack-width);
	}

	.telkari-design-1 .telkari-cta-link {
		min-width: 0;
		max-width: none;
		width: 100%;
	}
}

@media (max-width: 36rem) {
	.telkari-design-1 .telkari-cta-wrapper {
		width: min(7.5rem, calc(100vw - 1rem));
	}
}
