/**
 * Marc's Elementor Add-ons Styles
 *
 * @package Marcs_Elementor_Addons
 * @since 1.0.0
 */

/* Collapsible Content Widget */
.marcs-collapsible-wrapper {
	position: relative;
	width: 100%;
}

.marcs-collapsible-heading-wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 15px;
	width: 100%;
}

.marcs-collapsible-heading {
	margin: 0;
	flex: 1;
}

.marcs-collapsible-toggle {
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	padding: 0;
	margin: 0;
	transition: transform 0.2s ease;
	outline: none;
	flex-shrink: 0;
}

.marcs-collapsible-toggle:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
	border-radius: 2px;
}

.marcs-collapsible-toggle:hover {
	opacity: 0.8;
}

.marcs-collapsible-toggle-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	position: relative;
	width: 1em;
	height: 1em;
}

.marcs-collapsible-icon-closed,
.marcs-collapsible-icon-opened {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.2s ease;
	width: 100%;
	height: 100%;
}

.marcs-collapsible-wrapper.marcs-collapsible-open .marcs-collapsible-icon-closed {
	opacity: 0;
}

.marcs-collapsible-wrapper.marcs-collapsible-open .marcs-collapsible-icon-opened {
	opacity: 1;
}

.marcs-collapsible-wrapper:not(.marcs-collapsible-open) .marcs-collapsible-icon-closed {
	opacity: 1;
}

.marcs-collapsible-wrapper:not(.marcs-collapsible-open) .marcs-collapsible-icon-opened {
	opacity: 0;
}

.marcs-collapsible-content-area {
	margin-top: 15px;
}

.marcs-collapsible-content-wrapper {
	overflow: hidden;
	transition: max-height 300ms ease, opacity 300ms ease, padding-top 300ms ease, padding-bottom 300ms ease, margin-top 300ms ease, margin-bottom 300ms ease;
	max-height: 0;
	opacity: 0;
	padding-top: 0;
	padding-bottom: 0;
	margin-top: 0;
	margin-bottom: 0;
}

.marcs-collapsible-content-wrapper.marcs-collapsible-visible {
	max-height: 5000px;
	opacity: 1;
}

.marcs-collapsible-content-wrapper.marcs-collapsible-hidden {
	max-height: 0;
	opacity: 0;
}

/* Accessibility */
.marcs-collapsible-toggle[aria-expanded="true"] {
	/* Add any styles for expanded state */
}

.marcs-collapsible-toggle[aria-expanded="false"] {
	/* Add any styles for collapsed state */
}

/* RTL Support */
[dir="rtl"] .marcs-collapsible-heading-wrapper {
	flex-direction: row-reverse;
}

/* Editor Styles - Make draggable containers visible */
.elementor-editor-active .marcs-collapsible-nested-container {
	min-height: 50px;
	border: 2px dashed #d5dadf;
	border-radius: 4px;
	background-color: #f9fafb;
	position: relative;
	transition: border-color 0.2s ease, background-color 0.2s ease;
}

.elementor-editor-active .marcs-collapsible-nested-container:hover {
	border-color: #71d7f7;
	background-color: #f0f9ff;
}

.elementor-editor-active .marcs-collapsible-nested-container:empty::before {
	content: attr(data-placeholder);
	display: block;
	padding: 15px;
	color: #9ca3af;
	font-size: 13px;
	text-align: center;
	pointer-events: none;
}

.elementor-editor-active .marcs-collapsible-nested-container:empty::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 24px;
	height: 24px;
	background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 5V19M5 12H19' stroke='%239ca3af' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	opacity: 0.5;
	pointer-events: none;
}

/* Ensure containers are visible even when empty in editor */
.elementor-editor-active .marcs-collapsible-nested-container.marcs-collapsible-content-area:empty {
	min-height: 80px;
}

.elementor-editor-active .marcs-collapsible-nested-container.marcs-collapsible-content-wrapper:empty {
	min-height: 80px;
}

/* Custom Nested Accordion Widget */
.elementor-widget-custom-nested-accordion {
	--n-accordion-title-font-size: 20px;
	--n-accordion-title-flex-grow: initial;
	--n-accordion-title-justify-content: initial;
	--n-accordion-title-icon-order: -1;
	--n-accordion-border-width: 1px;
	--n-accordion-border-color: #d5d8dc;
	--n-accordion-border-style: solid;
	--n-accordion-item-title-flex-grow: initial;
	--n-accordion-item-title-space-between: 0px;
	--n-accordion-item-title-distance-from-content: 0px;
	--n-accordion-padding: 10px;
	--n-accordion-border-radius: 0px;
	--n-accordion-icon-size: 15px;
	--n-accordion-title-normal-color: #1f2124;
	--n-accordion-title-hover-color: #1f2124;
	--n-accordion-title-active-color: #1f2124;
	--n-accordion-icon-normal-color: var(--n-accordion-title-normal-color);
	--n-accordion-icon-hover-color: var(--n-accordion-title-hover-color);
	--n-accordion-icon-active-color: var(--n-accordion-title-active-color);
	--n-accordion-icon-gap: 0 10px;
	width: 100%;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion details > summary::-webkit-details-marker {
	display: none;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item {
	display: flex;
	flex-direction: column;
	position: relative;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item:not(:last-child) {
	margin-block-end: var(--n-accordion-item-title-space-between);
}

:where(.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item > .e-con) {
	border: var(--n-accordion-border-width) var(--n-accordion-border-style) var(--n-accordion-border-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title {
	align-items: center;
	border-color: var(--n-accordion-border-color);
	border-radius: var(--n-accordion-border-radius);
	border-style: var(--n-accordion-border-style);
	border-width: var(--n-accordion-border-width);
	color: var(--n-accordion-title-normal-color);
	cursor: pointer;
	display: flex;
	flex-direction: row;
	flex-grow: var(--n-menu-title-flex-grow);
	gap: var(--n-accordion-icon-gap);
	justify-content: var(--n-accordion-title-justify-content);
	list-style: none;
	padding: var(--n-accordion-padding);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header {
	display: flex;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header h1,
.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header h2,
.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header h3,
.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header h4,
.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header h5,
.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header h6,
.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-header p {
	margin-block-end: 0;
	margin-block-start: 0;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-text {
	align-items: center;
	font-size: var(--n-accordion-title-font-size);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-icon {
	align-items: center;
	display: flex;
	flex-direction: row;
	order: var(--n-accordion-title-icon-order);
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-icon span {
	height: var(--n-accordion-icon-size);
	width: auto;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-icon span > i {
	color: var(--n-accordion-icon-normal-color);
	font-size: var(--n-accordion-icon-size);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title-icon span > svg {
	fill: var(--n-accordion-icon-normal-color);
	height: var(--n-accordion-icon-size);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item-title > span {
	cursor: pointer;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item[open] > .marcs-custom-nested-accordion-item-title {
	color: var(--n-accordion-title-active-color);
	margin-block-end: var(--n-accordion-item-title-distance-from-content);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item[open] > .marcs-custom-nested-accordion-item-title .marcs-custom-nested-accordion-item-title-icon .e-opened {
	display: flex;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item[open] > .marcs-custom-nested-accordion-item-title .marcs-custom-nested-accordion-item-title-icon .e-closed {
	display: none;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item[open] > .marcs-custom-nested-accordion-item-title .marcs-custom-nested-accordion-item-title-icon span > i {
	color: var(--n-accordion-icon-active-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item[open] > .marcs-custom-nested-accordion-item-title .marcs-custom-nested-accordion-item-title-icon span > svg {
	fill: var(--n-accordion-icon-active-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item:not([open]):hover > .marcs-custom-nested-accordion-item-title {
	color: var(--n-accordion-title-hover-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item:not([open]):hover > .marcs-custom-nested-accordion-item-title .marcs-custom-nested-accordion-item-title-icon span > i {
	color: var(--n-accordion-icon-hover-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item:not([open]):hover > .marcs-custom-nested-accordion-item-title .marcs-custom-nested-accordion-item-title-icon span > svg {
	fill: var(--n-accordion-icon-hover-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item .marcs-custom-nested-accordion-item-title-icon .e-opened {
	display: none;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item .marcs-custom-nested-accordion-item-title-icon .e-closed {
	display: flex;
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item .marcs-custom-nested-accordion-item-title-icon span > svg {
	fill: var(--n-accordion-icon-normal-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item .marcs-custom-nested-accordion-item-title-icon span > i {
	color: var(--n-accordion-icon-normal-color);
}

.elementor-widget-custom-nested-accordion .marcs-custom-nested-accordion-item > span {
	cursor: pointer;
}

