/* Deution Builder frontend widgets */

.deution-richtext > :first-child { margin-top: 0; }
.deution-richtext > :last-child { margin-bottom: 0; }

.deution-gallery {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(var(--deution-cols, 3), minmax(0, 1fr));
}
.deution-gallery__item img { width: 100%; height: auto; display: block; border-radius: 10px; }

.deution-video { max-width: 100%; }
.deution-video iframe,
.deution-video video { max-width: 100%; }

.deution-icon { display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.deution-icon svg { width: 1em; height: 1em; display: block; }

.deution-tabs {
	border: 1px solid #eee;
	border-radius: 12px;
	overflow: hidden;
}
.deution-tabs__tablist {
	display: flex;
	flex-wrap: wrap;
	gap: 2px;
	padding: 6px;
	border-bottom: 1px solid #eee;
	background: #fafafa;
}
.deution-tabs__tab {
	appearance: none;
	border: 0;
	background: transparent;
	padding: 10px 12px;
	border-radius: 10px;
	cursor: pointer;
}
.deution-tabs__tab.is-active { background: #fff; box-shadow: 0 1px 0 rgba(0,0,0,0.03); }
.deution-tabs__panel { padding: 12px; }

.deution-accordion {
	border: 1px solid #eee;
	border-radius: 12px;
	overflow: hidden;
}
.deution-accordion__item + .deution-accordion__item { border-top: 1px solid #eee; }
.deution-accordion__title {
	width: 100%;
	text-align: left;
	appearance: none;
	border: 0;
	background: #fafafa;
	padding: 12px;
	cursor: pointer;
	font-weight: 600;
}
.deution-accordion__panel { padding: 12px; }

.deution-menu ul { list-style: none; margin: 0; padding: 0; }
.deution-menu > ul { display: flex; gap: 12px; }
.deution-menu a { text-decoration: none; }
.deution-menu li { position: relative; }
.deution-menu__toggle {
	appearance: none;
	border: 0;
	background: transparent;
	cursor: pointer;
	padding: 6px 8px;
	font-size: 12px;
}
.deution-menu__submenu { display: none; position: absolute; left: 0; top: 100%; min-width: 220px; background: #fff; border: 1px solid #eee; border-radius: 12px; padding: 10px; box-shadow: 0 10px 30px rgba(0,0,0,0.08); z-index: 9999; }
.deution-menu li.is-open > .deution-menu__submenu { display: block; }
.deution-menu li:hover > .deution-menu__submenu { display: block; }

/* Simple mega menu: wide dropdown */
.deution-menu--mega .deution-menu__submenu { min-width: 420px; }

.deution-breadcrumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin: 0; padding: 0; }
.deution-breadcrumbs a { text-decoration: none; }
.deution-breadcrumbs__sep { opacity: 0.6; }

.deution-search form { display: flex; gap: 8px; }
.deution-search input[type="search"] { flex: 1; padding: 10px 12px; border-radius: 12px; border: 1px solid #ddd; }
.deution-search button { padding: 10px 12px; border-radius: 12px; border: 1px solid #ddd; background: #fff; cursor: pointer; }

.deution-pagination nav ul { list-style: none; display: flex; gap: 8px; padding: 0; margin: 0; flex-wrap: wrap; }
.deution-pagination nav a,
.deution-pagination nav span { padding: 8px 10px; border: 1px solid #ddd; border-radius: 10px; text-decoration: none; }
.deution-pagination nav .current { background: #f5f5f5; }

/* Posts loop */
.deution-posts-loop__items {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(var(--deution-cols, 1), minmax(0, 1fr));
}
.deution-posts-loop__item {
	border: 1px solid #eee;
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	padding: 14px;
}
.deution-posts-loop__thumb img { width: 100%; height: auto; display: block; border-radius: 12px; }
.deution-posts-loop__title { margin: 10px 0 8px; font-size: 18px; }
.deution-posts-loop__excerpt { opacity: 0.9; }

@media (max-width: 720px) {
	.deution-menu > ul { flex-direction: column; gap: 6px; }
	.deution-menu__submenu { position: static; min-width: 0; box-shadow: none; border-radius: 10px; }
	.deution-menu li:hover > .deution-menu__submenu { display: none; }
	.deution-menu li.is-open > .deution-menu__submenu { display: block; }
}

/* Forms (Stage 10) */
.deution-form {
	border: 1px solid #eee;
	border-radius: 14px;
	padding: 14px;
	background: #fff;
	display: grid;
	gap: 12px;
}
.deution-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.deution-form__field { display: grid; gap: 6px; }
.deution-form__label { font-weight: 600; }
.deution-form__control {
	width: 100%;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid #ddd;
	background: #fff;
	box-sizing: border-box;
}
.deution-form__control:focus { outline: none; border-color: #bbb; box-shadow: 0 0 0 3px rgba(0,0,0,0.05); }
.deution-form__message { font-size: 14px; min-height: 18px; }
.deution-form__message.is-error { color: #b42318; }
.deution-form__message.is-success { color: #027a48; }
.deution-form__submit {
	justify-self: start;
	padding: 10px 14px;
	border-radius: 12px;
	border: 1px solid #ddd;
	background: #fff;
	cursor: pointer;
	font-weight: 600;
}
.deution-form__submit[disabled] { opacity: 0.6; cursor: not-allowed; }

/* Popups (Stage 10) */
.deution-popup-overlay {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 18px;
	background: rgba(0, 0, 0, 0.55);
}
.deution-popup {
	position: relative;
	width: min(680px, 100%);
	max-height: min(82vh, 900px);
	overflow: auto;
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 18px 60px rgba(0,0,0,0.25);
	padding: 18px;
}
.deution-popup__close {
	position: absolute;
	top: 10px;
	right: 10px;
	width: 34px;
	height: 34px;
	border-radius: 10px;
	border: 1px solid #eee;
	background: #fff;
	cursor: pointer;
	line-height: 1;
}
.deution-popup__close:hover { background: #fafafa; }

body.deution-popup-open { overflow: hidden; }
