/**
 * Configurator Styles
 *
 * @package Tobalt_Memorial
 * @author  Tobalt — https://tobalt.lt
 */

/* Variables */
:root {
	--tm-primary: #2c3e50;
	--tm-primary-hover: #1a252f;
	--tm-secondary: #6b7280;
	--tm-success: #059669;
	--tm-error: #dc2626;
	--tm-border: #d1d5db;
	--tm-bg: #f9fafb;
	--tm-radius: 8px;
	--tm-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Container */
.tobalt-memorial-configurator {
	max-width: 900px;
	margin: 0 auto;
	padding: 20px;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Progress Steps */
.tobalt-memorial-steps {
	margin-bottom: 40px;
}

.tobalt-memorial-steps__list {
	display: flex;
	justify-content: space-between;
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
}

.tobalt-memorial-steps__list::before {
	content: '';
	position: absolute;
	top: 16px;
	left: 10%;
	right: 10%;
	height: 2px;
	background: var(--tm-border);
	z-index: 0;
}

.tobalt-memorial-steps__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	position: relative;
	z-index: 1;
}

.tobalt-memorial-steps__number {
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: #fff;
	border: 2px solid var(--tm-border);
	font-weight: 600;
	color: var(--tm-secondary);
	transition: all 0.3s;
}

.tobalt-memorial-steps__label {
	font-size: 13px;
	color: var(--tm-secondary);
	text-align: center;
}

.tobalt-memorial-steps__item.active .tobalt-memorial-steps__number {
	background: var(--tm-primary);
	border-color: var(--tm-primary);
	color: #fff;
}

.tobalt-memorial-steps__item.completed .tobalt-memorial-steps__number {
	background: var(--tm-success);
	border-color: var(--tm-success);
	color: #fff;
}

.tobalt-memorial-steps__item.active .tobalt-memorial-steps__label,
.tobalt-memorial-steps__item.completed .tobalt-memorial-steps__label {
	color: var(--tm-primary);
	font-weight: 500;
}

/* Wizard */
.tobalt-memorial-wizard {
	background: #fff;
	border-radius: var(--tm-radius);
	box-shadow: var(--tm-shadow);
	padding: 30px;
	min-height: 400px;
}

/* Steps */
.tobalt-memorial-step[hidden] {
	display: none;
}

.tobalt-memorial-step__title {
	margin: 0 0 20px;
	font-size: 24px;
	font-weight: 600;
	color: var(--tm-primary);
}

.tobalt-memorial-step__desc {
	margin: 0 0 20px;
	color: var(--tm-secondary);
}

/* Loading */
.tobalt-memorial-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 40px;
	color: var(--tm-secondary);
}

.tobalt-memorial-spinner {
	width: 24px;
	height: 24px;
	border: 3px solid var(--tm-border);
	border-top-color: var(--tm-primary);
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

/* Shapes Grid */
.tobalt-memorial-shapes {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 16px;
	margin-bottom: 20px;
}

.tobalt-memorial-shape {
	padding: 20px;
	background: var(--tm-bg);
	border: 2px solid var(--tm-border);
	border-radius: var(--tm-radius);
	cursor: pointer;
	transition: all 0.2s;
	text-align: center;
}

.tobalt-memorial-shape:hover {
	border-color: var(--tm-primary);
}

.tobalt-memorial-shape.selected {
	border-color: var(--tm-primary);
	background: rgba(44, 62, 80, 0.05);
}

.tobalt-memorial-shape__preview {
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
}

.tobalt-memorial-shape__preview svg {
	width: auto;
	height: 80px;
	color: #666;
}

.tobalt-memorial-shape.selected .tobalt-memorial-shape__preview svg {
	color: var(--tm-primary);
}

.tobalt-memorial-shape__name {
	font-size: 14px;
	font-weight: 500;
	color: var(--tm-primary);
}

/* Dimensions */
.tobalt-memorial-dimensions {
	margin-top: 30px;
	padding-top: 20px;
	border-top: 1px solid var(--tm-border);
}

.tobalt-memorial-dimensions h3 {
	margin: 0 0 16px;
	font-size: 16px;
}

.tobalt-memorial-dimensions__options {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

.tobalt-memorial-dimension {
	padding: 12px 20px;
	background: var(--tm-bg);
	border: 2px solid var(--tm-border);
	border-radius: var(--tm-radius);
	cursor: pointer;
	transition: all 0.2s;
}

.tobalt-memorial-dimension:hover {
	border-color: var(--tm-primary);
}

.tobalt-memorial-dimension.selected {
	border-color: var(--tm-primary);
	background: rgba(44, 62, 80, 0.05);
}

.tobalt-memorial-dimension__label {
	font-weight: 500;
	margin-bottom: 4px;
}

.tobalt-memorial-dimension__size {
	font-size: 13px;
	color: var(--tm-secondary);
}

/* Materials Grid */
.tobalt-memorial-materials {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 16px;
}

.tobalt-memorial-material {
	padding: 16px;
	background: #fff;
	border: 2px solid var(--tm-border);
	border-radius: var(--tm-radius);
	cursor: pointer;
	transition: all 0.2s;
	text-align: center;
}

.tobalt-memorial-material:hover {
	border-color: var(--tm-primary);
}

.tobalt-memorial-material.selected {
	border-color: var(--tm-primary);
	box-shadow: 0 0 0 3px rgba(44, 62, 80, 0.1);
}

.tobalt-memorial-material__swatch {
	width: 100%;
	height: 60px;
	border-radius: 4px;
	margin-bottom: 12px;
	border: 1px solid rgba(0, 0, 0, 0.1);
}

.tobalt-memorial-material__name {
	font-weight: 500;
	font-size: 14px;
}

.tobalt-memorial-material__finish {
	font-size: 12px;
	color: var(--tm-secondary);
	margin-top: 4px;
}

/* Inscriptions */
.tobalt-memorial-inscriptions {
	display: flex;
	flex-direction: column;
	gap: 20px;
	margin-bottom: 20px;
}

.tobalt-memorial-inscription {
	padding: 20px;
	background: var(--tm-bg);
	border-radius: var(--tm-radius);
}

.tobalt-memorial-inscription__controls {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 12px;
}

.tobalt-memorial-inscription__controls label {
	font-weight: 500;
}

.tobalt-memorial-inscription__font {
	padding: 8px 12px;
	border: 1px solid var(--tm-border);
	border-radius: 4px;
	font-size: 14px;
	min-width: 180px;
}

.tobalt-memorial-inscription__text {
	width: 100%;
	padding: 12px;
	border: 1px solid var(--tm-border);
	border-radius: 4px;
	font-size: 16px;
	resize: vertical;
	font-family: inherit;
}

.tobalt-memorial-inscription__text:focus {
	outline: none;
	border-color: var(--tm-primary);
}

/* Symbols Grid */
.tobalt-memorial-symbols {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
	gap: 12px;
	margin-bottom: 30px;
}

.tobalt-memorial-symbol {
	padding: 12px;
	background: var(--tm-bg);
	border: 2px solid var(--tm-border);
	border-radius: var(--tm-radius);
	cursor: pointer;
	transition: all 0.2s;
	text-align: center;
}

.tobalt-memorial-symbol:hover {
	border-color: var(--tm-primary);
}

.tobalt-memorial-symbol.selected {
	border-color: var(--tm-primary);
	background: rgba(44, 62, 80, 0.05);
}

.tobalt-memorial-symbol__preview {
	width: 50px;
	height: 50px;
	margin: 0 auto 8px;
}

.tobalt-memorial-symbol__preview svg,
.tobalt-memorial-symbol__preview img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.tobalt-memorial-symbol__name {
	font-size: 12px;
	color: var(--tm-secondary);
}

/* Selected symbols */
.tobalt-memorial-selected-symbols h3 {
	margin: 0 0 12px;
	font-size: 16px;
}

.tobalt-memorial-selected-symbols__list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.tobalt-memorial-selected-symbols__list:empty::after {
	content: 'Simboliai nepasirinkti';
	color: var(--tm-secondary);
	font-style: italic;
}

.tobalt-memorial-selected-symbol {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px;
	background: var(--tm-bg);
	border-radius: 20px;
	font-size: 13px;
}

.tobalt-memorial-selected-symbol__remove {
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	font-size: 16px;
	color: var(--tm-error);
	line-height: 1;
}

/* Preview */
.tobalt-memorial-preview {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
	margin-bottom: 30px;
}

@media (max-width: 768px) {
	.tobalt-memorial-preview {
		grid-template-columns: 1fr;
	}
}

.tobalt-memorial-preview__visual {
	background: var(--tm-bg);
	border-radius: var(--tm-radius);
	padding: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 300px;
}

.tobalt-memorial-preview__memorial {
	width: 150px;
	height: 200px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 20px;
	border-radius: 4px;
	color: #fff;
	text-align: center;
}

.tobalt-memorial-preview__summary h3 {
	margin: 0 0 16px;
	font-size: 18px;
}

.tobalt-memorial-preview__summary table {
	width: 100%;
	border-collapse: collapse;
}

.tobalt-memorial-preview__summary th,
.tobalt-memorial-preview__summary td {
	padding: 10px;
	text-align: left;
	border-bottom: 1px solid var(--tm-border);
}

.tobalt-memorial-preview__summary th {
	font-weight: 500;
	color: var(--tm-secondary);
	width: 120px;
}

/* Form */
.tobalt-memorial-form {
	margin-top: 30px;
	padding-top: 30px;
	border-top: 1px solid var(--tm-border);
}

.tobalt-memorial-form h3 {
	margin: 0 0 20px;
	font-size: 18px;
}

.tobalt-memorial-form__row {
	margin-bottom: 16px;
}

.tobalt-memorial-form__row--two {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

@media (max-width: 600px) {
	.tobalt-memorial-form__row--two {
		grid-template-columns: 1fr;
	}
}

.tobalt-memorial-form__field label {
	display: block;
	margin-bottom: 6px;
	font-weight: 500;
}

.tobalt-memorial-form__field input,
.tobalt-memorial-form__field select,
.tobalt-memorial-form__field textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--tm-border);
	border-radius: 4px;
	font-size: 15px;
	font-family: inherit;
}

.tobalt-memorial-form__field input:focus,
.tobalt-memorial-form__field select:focus,
.tobalt-memorial-form__field textarea:focus {
	outline: none;
	border-color: var(--tm-primary);
}

.tobalt-memorial-form__field--checkbox {
	display: flex;
	align-items: flex-start;
}

.tobalt-memorial-form__field--checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: normal;
	cursor: pointer;
}

.tobalt-memorial-form__field--checkbox input {
	width: auto;
	margin-top: 3px;
}

.tobalt-memorial-form__partners {
	margin: 30px 0;
	padding: 20px;
	background: var(--tm-bg);
	border-radius: var(--tm-radius);
}

.tobalt-memorial-form__partners h3 {
	margin: 0 0 8px;
}

.tobalt-memorial-form__partners > p {
	margin: 0 0 16px;
	color: var(--tm-secondary);
}

.tobalt-memorial-partners-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.tobalt-memorial-partner-chip {
	display: inline-block;
	padding: 6px 12px;
	background: #fff;
	border: 1px solid var(--tm-border);
	border-radius: 20px;
	font-size: 13px;
}

.tobalt-memorial-form__actions {
	margin-top: 30px;
	text-align: center;
}

/* Buttons */
.tobalt-memorial-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 20px;
	border: none;
	border-radius: 4px;
	font-size: 15px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.2s;
	font-family: inherit;
}

.tobalt-memorial-btn--primary {
	background: var(--tm-primary);
	color: #fff;
}

.tobalt-memorial-btn--primary:hover {
	background: var(--tm-primary-hover);
}

.tobalt-memorial-btn--secondary {
	background: #fff;
	color: var(--tm-primary);
	border: 1px solid var(--tm-border);
}

.tobalt-memorial-btn--secondary:hover {
	background: var(--tm-bg);
}

.tobalt-memorial-btn--large {
	padding: 14px 32px;
	font-size: 16px;
}

.tobalt-memorial-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Navigation */
.tobalt-memorial-nav {
	display: flex;
	justify-content: space-between;
	margin-top: 30px;
	padding-top: 20px;
	border-top: 1px solid var(--tm-border);
}

/* Success state */
.tobalt-memorial-success {
	text-align: center;
	padding: 60px 20px;
}

.tobalt-memorial-success__icon {
	width: 80px;
	height: 80px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	background: var(--tm-success);
	color: #fff;
	border-radius: 50%;
	font-size: 40px;
}

.tobalt-memorial-success h2 {
	margin: 0 0 16px;
	font-size: 28px;
	color: var(--tm-primary);
}

.tobalt-memorial-success p {
	color: var(--tm-secondary);
	max-width: 400px;
	margin: 0 auto 16px;
}

.tobalt-memorial-success__ref {
	font-size: 18px;
	margin-bottom: 30px;
}

/* Error state */
.tobalt-memorial-error {
	padding: 12px;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 4px;
	color: var(--tm-error);
	margin-bottom: 20px;
}

/* Required indicator */
.required {
	color: var(--tm-error);
}

/* Responsive */
@media (max-width: 600px) {
	.tobalt-memorial-configurator {
		padding: 10px;
	}

	.tobalt-memorial-steps__label {
		display: none;
	}

	.tobalt-memorial-wizard {
		padding: 20px;
	}

	.tobalt-memorial-step__title {
		font-size: 20px;
	}

	.tobalt-memorial-shapes {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ========================================
   V2: Safety Indicator
   ======================================== */
.tobalt-memorial-safety {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	border-radius: var(--tm-radius);
	margin-top: 20px;
	font-size: 14px;
}

.tobalt-memorial-safety__icon {
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	font-weight: bold;
	font-size: 16px;
}

.tobalt-memorial-safety__text {
	font-weight: 600;
}

.tobalt-memorial-safety__desc {
	color: inherit;
	opacity: 0.8;
}

/* Safe - Green */
.tobalt-memorial-safety--safe {
	background: #ecfdf5;
	border: 1px solid #a7f3d0;
	color: #065f46;
}

.tobalt-memorial-safety--safe .tobalt-memorial-safety__icon {
	background: #059669;
	color: #fff;
}

/* Tight - Amber */
.tobalt-memorial-safety--tight {
	background: #fffbeb;
	border: 1px solid #fde68a;
	color: #92400e;
}

.tobalt-memorial-safety--tight .tobalt-memorial-safety__icon {
	background: #d97706;
	color: #fff;
}

/* Not Recommended - Red */
.tobalt-memorial-safety--notRecommended {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
}

.tobalt-memorial-safety--notRecommended .tobalt-memorial-safety__icon {
	background: #dc2626;
	color: #fff;
}

/* Unknown */
.tobalt-memorial-safety--unknown {
	background: var(--tm-bg);
	border: 1px solid var(--tm-border);
	color: var(--tm-secondary);
}

.tobalt-memorial-safety--unknown .tobalt-memorial-safety__icon {
	background: var(--tm-secondary);
	color: #fff;
}

/* ========================================
   V2: Font Recommendations
   ======================================== */
.tobalt-memorial-inscription__font optgroup {
	font-weight: 600;
	font-style: normal;
}

.tobalt-memorial-inscription__font option {
	font-weight: normal;
	padding: 4px 8px;
}

/* Recommended badge in preview */
.tobalt-memorial-font-recommended {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	background: #fef3c7;
	border-radius: 12px;
	font-size: 11px;
	color: #92400e;
	margin-left: 8px;
}

.tobalt-memorial-font-recommended::before {
	content: '★';
}

/* ========================================
   V2: Enhanced Dimension Presets
   ======================================== */
.tobalt-memorial-dimension--recommended {
	border-color: var(--tm-success);
	position: relative;
}

.tobalt-memorial-dimension--recommended::after {
	content: 'Populiariausias';
	position: absolute;
	top: -10px;
	right: 10px;
	background: var(--tm-success);
	color: #fff;
	font-size: 10px;
	padding: 2px 8px;
	border-radius: 10px;
	font-weight: 500;
}

/* ========================================
   V2: Enhanced Preview with Safety
   ======================================== */
.tobalt-memorial-preview__safety {
	margin-top: 16px;
	padding: 12px;
	background: var(--tm-bg);
	border-radius: 4px;
}

.tobalt-memorial-preview__safety-label {
	font-size: 12px;
	color: var(--tm-secondary);
	margin-bottom: 4px;
}

.tobalt-memorial-preview__safety-value {
	font-weight: 600;
}

.tobalt-memorial-preview__safety-value--safe {
	color: #059669;
}

.tobalt-memorial-preview__safety-value--tight {
	color: #d97706;
}

.tobalt-memorial-preview__safety-value--notRecommended {
	color: #dc2626;
}

/* ========================================
   V4: Location/Cemetery Selection
   ======================================== */
.tobalt-memorial-location {
	max-width: 500px;
}

.tobalt-memorial-location__row {
	margin-bottom: 20px;
}

.tobalt-memorial-location__field label {
	display: block;
	margin-bottom: 8px;
	font-weight: 500;
	color: var(--tm-primary);
}

.tobalt-memorial-location__field select,
.tobalt-memorial-location__field input[type="text"] {
	width: 100%;
	padding: 12px;
	border: 1px solid var(--tm-border);
	border-radius: var(--tm-radius);
	font-size: 15px;
	font-family: inherit;
	background: #fff;
}

.tobalt-memorial-location__field select:focus,
.tobalt-memorial-location__field input:focus {
	outline: none;
	border-color: var(--tm-primary);
	box-shadow: 0 0 0 3px rgba(44, 62, 80, 0.1);
}

.tobalt-memorial-location__field select:disabled {
	background: var(--tm-bg);
	color: var(--tm-secondary);
	cursor: not-allowed;
}

.tobalt-memorial-field__hint {
	margin: 8px 0;
	font-size: 13px;
	color: var(--tm-secondary);
}

.tobalt-memorial-location__skip {
	margin-top: 24px;
	padding-top: 16px;
	border-top: 1px solid var(--tm-border);
}

.tobalt-memorial-location__skip label {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	color: var(--tm-secondary);
	font-size: 14px;
}

.tobalt-memorial-location__skip input {
	width: 18px;
	height: 18px;
	cursor: pointer;
}

/* Ruleset Info Box */
.tobalt-memorial-ruleset-info {
	display: flex;
	gap: 16px;
	padding: 16px;
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	border-radius: var(--tm-radius);
	margin-top: 24px;
}

.tobalt-memorial-ruleset-info__icon {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #3b82f6;
	color: #fff;
	border-radius: 50%;
	font-size: 20px;
	flex-shrink: 0;
}

.tobalt-memorial-ruleset-info__content h4 {
	margin: 0 0 8px;
	font-size: 15px;
	color: #1e40af;
}

.tobalt-memorial-ruleset-info__content p {
	margin: 0 0 8px;
	font-weight: 600;
	color: #1e3a8a;
}

.tobalt-memorial-ruleset-info__content ul {
	margin: 0;
	padding-left: 20px;
	color: #1e40af;
	font-size: 14px;
}

.tobalt-memorial-ruleset-info__content li {
	margin-bottom: 4px;
}

/* Restricted/Allowed item badges */
.tobalt-memorial-shape--restricted,
.tobalt-memorial-material--restricted,
.tobalt-memorial-symbol--restricted {
	position: relative;
	opacity: 0.5;
	pointer-events: none;
}

.tobalt-memorial-shape--restricted::after,
.tobalt-memorial-material--restricted::after,
.tobalt-memorial-symbol--restricted::after {
	content: 'Negalimas';
	position: absolute;
	top: 4px;
	right: 4px;
	background: var(--tm-error);
	color: #fff;
	font-size: 10px;
	padding: 2px 6px;
	border-radius: 8px;
}

.tobalt-memorial-material--recommended {
	position: relative;
}

.tobalt-memorial-material--recommended::before {
	content: '★';
	position: absolute;
	top: 4px;
	left: 4px;
	background: #fef3c7;
	color: #92400e;
	font-size: 12px;
	padding: 2px 6px;
	border-radius: 8px;
}

/* Dimension exceeded warning */
.tobalt-memorial-dimension--exceeded {
	border-color: var(--tm-error);
	background: #fef2f2;
}

.tobalt-memorial-dimension--exceeded .tobalt-memorial-dimension__label::after {
	content: ' (viršija limitą)';
	color: var(--tm-error);
	font-weight: normal;
	font-size: 11px;
}
