/**
 * Mitmach-Kalender – Frontend-Styles
 * Minimales, wartbares CSS ohne Framework-Abhängigkeit.
 */

/* ── Basis ─────────────────────────────────────────────────────────────────── */

.mk-wrap {
	max-width: 960px;
	margin: 0 auto;
	padding: 1.5rem 1rem;
	font-family: inherit;
}

/* ── Meldungen ──────────────────────────────────────────────────────────────── */

.mk-error {
	background: #fdecea;
	border-left: 4px solid #c0392b;
	color: #7b241c;
	padding: .75rem 1rem;
	margin-bottom: 1rem;
	border-radius: 4px;
}

.mk-success {
	background: #eafaf1;
	border-left: 4px solid #27ae60;
	color: #1e8449;
	padding: .75rem 1rem;
	margin-bottom: 1rem;
	border-radius: 4px;
}

.mk-notice,
.mk-vote-inactive {
	background: #fef9e7;
	border-left: 4px solid #f39c12;
	color: #7d6608;
	padding: .75rem 1rem;
	margin-bottom: 1rem;
	border-radius: 4px;
}

.mk-empty {
	color: #888;
	font-style: italic;
}

/* ── Formulare ──────────────────────────────────────────────────────────────── */

.mk-form {
	max-width: 480px;
}

.mk-field {
	margin-bottom: 1.25rem;
}

.mk-field label {
	display: block;
	font-weight: 600;
	margin-bottom: .35rem;
}

.mk-field input[type="text"],
.mk-field input[type="email"],
.mk-field input[type="number"],
.mk-field input[type="password"],
.mk-field select {
	width: 100%;
	padding: .5rem .75rem;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 1rem;
	box-sizing: border-box;
}

.mk-field input:focus,
.mk-field select:focus {
	outline: 2px solid #0073aa;
	border-color: #0073aa;
}

.mk-field .description,
.mk-hint {
	font-size: .875rem;
	color: #666;
	margin-top: .25rem;
}

/* ── Buttons ────────────────────────────────────────────────────────────────── */

.mk-button {
	display: inline-block;
	padding: .6rem 1.4rem;
	background: #0073aa;
	color: #fff;
	border: none;
	border-radius: 4px;
	font-size: 1rem;
	cursor: pointer;
	text-decoration: none;
	transition: background .15s;
}

.mk-button:hover,
.mk-button:focus {
	background: #005a87;
}

.mk-button--secondary {
	background: #555;
}

.mk-button--secondary:hover {
	background: #333;
}

.mk-button:disabled {
	opacity: .6;
	cursor: not-allowed;
}

/* ── Galerie-Grid ───────────────────────────────────────────────────────────── */

.mk-gallery-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 280px, 1fr ) );
	gap: 1.5rem;
	margin-top: 1.5rem;
}

.mk-gallery-item {
	border: 1px solid #ddd;
	border-radius: 6px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 2px 6px rgba(0,0,0,.06);
}

.mk-gallery-image img,
.mk-photo-thumb {
	width: 100%;
	height: 220px;
	object-fit: cover;
	display: block;
}

.mk-no-image {
	height: 220px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f0f0f0;
	color: #aaa;
	font-size: .875rem;
}

.mk-gallery-info {
	padding: .75rem 1rem 1rem;
}

.mk-photo-title {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 .5rem;
}

.mk-photo-meta {
	list-style: none;
	margin: 0 0 .75rem;
	padding: 0;
	font-size: .875rem;
	color: #555;
}

.mk-photo-meta li {
	margin-bottom: .2rem;
}

.mk-label {
	font-weight: 600;
	margin-right: .25rem;
}

/* ── Bewertungssterne ───────────────────────────────────────────────────────── */

.mk-stars {
	border: none;
	padding: 0;
	margin: .5rem 0;
}

.mk-stars legend {
	font-weight: 600;
	margin-bottom: .35rem;
	font-size: .875rem;
}

.mk-star-label {
	cursor: pointer;
	font-size: 1.6rem;
	color: #ccc;
	transition: color .1s;
	display: inline-block;
}

.mk-star-label:hover,
.mk-star-label:hover ~ .mk-star-label,
.mk-star-label.active {
	color: #f5a623;
}

/* Eingabe-Radio ausblenden */
.mk-star-input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.mk-rating-display {
	font-size: .875rem;
	color: #555;
	margin-bottom: .5rem;
}

.mk-voted-notice {
	color: #27ae60;
	font-size: .875rem;
}

.mk-vote-msg {
	display: block;
	margin-top: .35rem;
	font-size: .85rem;
}

/* ── Rangliste ──────────────────────────────────────────────────────────────── */

.mk-ranking-table {
	width: 100%;
	border-collapse: collapse;
	margin-top: 1rem;
	font-size: .9rem;
}

.mk-ranking-table th,
.mk-ranking-table td {
	padding: .6rem .75rem;
	border-bottom: 1px solid #e0e0e0;
	text-align: left;
	vertical-align: middle;
}

.mk-ranking-table thead th {
	background: #f7f7f7;
	font-weight: 700;
}

.mk-top-1 { background: #fffde7; }
.mk-top-2 { background: #f5f5f5; }
.mk-top-3 { background: #fff8f0; }

.mk-rank-number {
	font-size: 1.1rem;
	font-weight: 700;
	color: #555;
}

.mk-top-1 .mk-rank-number { color: #f5a623; }
.mk-top-2 .mk-rank-number { color: #7f8c8d; }
.mk-top-3 .mk-rank-number { color: #a04000; }

.mk-rank-thumb {
	width: 60px;
	height: 45px;
	object-fit: cover;
	border-radius: 3px;
}

.mk-avg-col {
	text-align: center;
}

.mk-count-col {
	text-align: center;
}

.mk-no-votes {
	color: #aaa;
}

/* ── Submit-Feedback ────────────────────────────────────────────────────────── */

.mk-submit-response {
	margin-bottom: 1rem;
	padding: .75rem 1rem;
	border-radius: 4px;
	border-left: 4px solid transparent;
}

.mk-submit-response.success {
	background: #eafaf1;
	border-color: #27ae60;
	color: #1e8449;
}

.mk-submit-response.error {
	background: #fdecea;
	border-color: #c0392b;
	color: #7b241c;
}

/* ── Responsive ─────────────────────────────────────────────────────────────── */

@media ( max-width: 600px ) {
	.mk-gallery-grid {
		grid-template-columns: 1fr;
	}
	.mk-ranking-table .mk-thumb-col {
		display: none;
	}
}
