/* ============================================================
 * WS Domain Search – Styles
 * Eindeutiges Prefix: ws-domain-*
 * Mobile-first, modernes Hosting-/Cloud-Design.
 * ============================================================ */

.ws-domain-search {
	--ws-bg:           #ffffff;
	--ws-bg-alt:       #f5f7fb;
	--ws-fg:           #1f2937;
	--ws-fg-muted:     #6b7280;
	--ws-border:       #e5e7eb;
	--ws-primary:      #2563eb;
	--ws-primary-hover:#1d4ed8;
	--ws-accent:       #0ea5e9;
	--ws-success:      #16a34a;
	--ws-success-bg:   #ecfdf5;
	--ws-warn:         #d97706;
	--ws-warn-bg:      #fef3c7;
	--ws-danger:       #dc2626;
	--ws-danger-bg:    #fef2f2;
	--ws-radius:       14px;
	--ws-radius-sm:    8px;
	--ws-shadow:       0 8px 30px rgba(15, 23, 42, 0.08);
	--ws-shadow-sm:    0 2px 8px rgba(15, 23, 42, 0.06);

	box-sizing: border-box;
	max-width: 920px;
	margin: 0 auto;
	padding: 28px;
	background: var(--ws-bg);
	color: var(--ws-fg);
	border-radius: var(--ws-radius);
	box-shadow: var(--ws-shadow);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;
	line-height: 1.5;
}

.ws-domain-search *,
.ws-domain-search *::before,
.ws-domain-search *::after {
	box-sizing: inherit;
}

/* ---------- Header ---------- */
.ws-domain-search__header {
	text-align: center;
	margin-bottom: 22px;
}

.ws-domain-search__title {
	margin: 0 0 6px;
	font-size: clamp(1.4rem, 2.2vw, 1.8rem);
	font-weight: 700;
	color: var(--ws-fg);
}

.ws-domain-search__subtitle {
	margin: 0;
	color: var(--ws-fg-muted);
	font-size: 0.98rem;
}

/* ---------- Suchformular ---------- */
.ws-domain-search__form {
	margin: 0 0 18px;
}

.ws-domain-search__input-wrap {
	display: flex;
	flex-direction: column;
	gap: 10px;
	background: var(--ws-bg-alt);
	padding: 10px;
	border-radius: var(--ws-radius);
	border: 1px solid var(--ws-border);
}

.ws-domain-search__input {
	flex: 1 1 auto;
	min-width: 0;
	padding: 14px 16px;
	font-size: 1.05rem;
	border: 1px solid var(--ws-border);
	border-radius: var(--ws-radius-sm);
	background: #fff;
	color: var(--ws-fg);
	outline: none;
	transition: border-color .15s ease, box-shadow .15s ease;
}

.ws-domain-search__input:focus {
	border-color: var(--ws-primary);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}

.ws-domain-search__submit {
	appearance: none;
	border: 0;
	padding: 14px 22px;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: var(--ws-primary);
	border-radius: var(--ws-radius-sm);
	cursor: pointer;
	transition: background .15s ease, transform .05s ease;
}

.ws-domain-search__submit:hover {
	background: var(--ws-primary-hover);
}

.ws-domain-search__submit:active {
	transform: translateY(1px);
}

.ws-domain-search__submit[disabled] {
	opacity: .65;
	cursor: not-allowed;
}

.ws-domain-search__hint {
	margin: 8px 4px 0;
	min-height: 1.1em;
	font-size: 0.9rem;
	color: var(--ws-fg-muted);
}

.ws-domain-search__hint--error {
	color: var(--ws-danger);
}

@media (min-width: 640px) {
	.ws-domain-search__input-wrap {
		flex-direction: row;
		align-items: stretch;
	}
}

/* ---------- Ergebnisliste ---------- */
.ws-domain-search__results {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin-bottom: 22px;
}

@media (min-width: 720px) {
	.ws-domain-search__results {
		grid-template-columns: 1fr 1fr;
	}
}

.ws-domain-search__card {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 10px 16px;
	padding: 14px 16px;
	background: #fff;
	border: 1px solid var(--ws-border);
	border-radius: var(--ws-radius-sm);
	box-shadow: var(--ws-shadow-sm);
	transition: border-color .15s ease, transform .12s ease;
}

.ws-domain-search__card:hover {
	border-color: #c7d2fe;
}

.ws-domain-search__card--available {
	border-color: #bbf7d0;
	background: linear-gradient(180deg, #fff, var(--ws-success-bg));
	order: -1;
}

.ws-domain-search__card--taken {
	opacity: 0.85;
}

.ws-domain-search__card--invalid,
.ws-domain-search__card--error {
	border-color: #fecaca;
	background: linear-gradient(180deg, #fff, var(--ws-danger-bg));
}

.ws-domain-search__card-main {
	min-width: 0;
}

.ws-domain-search__domain {
	font-weight: 700;
	font-size: 1.05rem;
	word-break: break-all;
	color: var(--ws-fg);
}

.ws-domain-search__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 12px;
	margin-top: 4px;
	font-size: 0.9rem;
	color: var(--ws-fg-muted);
}

.ws-domain-search__price {
	font-weight: 600;
	color: var(--ws-fg);
}

.ws-domain-search__status {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: .02em;
	text-transform: uppercase;
}

.ws-domain-search__status--available {
	background: var(--ws-success-bg);
	color: var(--ws-success);
}

.ws-domain-search__status--confirmed {
	background: var(--ws-success);
	color: #fff;
}

.ws-domain-search__status--taken {
	background: #f3f4f6;
	color: var(--ws-fg-muted);
}

.ws-domain-search__status--invalid,
.ws-domain-search__status--error {
	background: var(--ws-danger-bg);
	color: var(--ws-danger);
}

.ws-domain-search__status--pending {
	background: var(--ws-warn-bg);
	color: var(--ws-warn);
}

.ws-domain-search__select {
	appearance: none;
	border: 0;
	padding: 10px 16px;
	background: var(--ws-primary);
	color: #fff;
	font-weight: 600;
	font-size: 0.92rem;
	border-radius: var(--ws-radius-sm);
	cursor: pointer;
	transition: background .15s ease;
	white-space: nowrap;
}

.ws-domain-search__select:hover {
	background: var(--ws-primary-hover);
}

.ws-domain-search__select[disabled] {
	background: #cbd5e1;
	cursor: not-allowed;
}

.ws-domain-search__select--selected {
	background: var(--ws-success);
}

/* ---------- Skeleton / Loading ---------- */
.ws-domain-search__card--loading .ws-domain-search__status {
	background: #e5e7eb;
	color: transparent;
	min-width: 120px;
}

.ws-domain-search__spinner {
	display: inline-block;
	width: 14px;
	height: 14px;
	border: 2px solid currentColor;
	border-right-color: transparent;
	border-radius: 50%;
	animation: ws-domain-spin 0.7s linear infinite;
	vertical-align: -2px;
}

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

/* ---------- Auswahlbereich ---------- */
.ws-domain-search__selection {
	border-top: 1px solid var(--ws-border);
	padding-top: 18px;
}

.ws-domain-search__selection-title {
	margin: 0 0 10px;
	font-size: 1.05rem;
	font-weight: 700;
}

.ws-domain-search__selection-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 8px;
}

.ws-domain-search__selection-list:empty::before {
	content: attr(data-empty-text);
	color: var(--ws-fg-muted);
	font-style: italic;
	font-size: 0.95rem;
}

.ws-domain-search__selection-item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	background: var(--ws-success-bg);
	border: 1px solid #bbf7d0;
	border-radius: var(--ws-radius-sm);
}

.ws-domain-search__selection-domain {
	font-weight: 700;
	color: var(--ws-fg);
}

.ws-domain-search__selection-price {
	color: var(--ws-fg-muted);
}

.ws-domain-search__selection-remove {
	margin-left: auto;
	appearance: none;
	border: 0;
	background: transparent;
	color: var(--ws-danger);
	cursor: pointer;
	font-weight: 600;
	font-size: 0.9rem;
	padding: 4px 6px;
	border-radius: 6px;
}

.ws-domain-search__selection-remove:hover {
	background: rgba(220, 38, 38, 0.08);
}
