/* Kunstnerportalen - frontend-komponenter (formularer, kort, galleri).
   Layout/typografi-rammen leveres af temaet; her bor de genbrugelige
   kp-* komponenter, så de ser ens ud i shortcodes og temaets skabeloner. */

:root {
	--kp-accent: #1f3a5f;
	--kp-accent-2: #c2703d;
	--kp-bg-soft: #f5f3ef;
	--kp-border: #e2ddd5;
	--kp-text: #23211e;
	--kp-muted: #6f6a62;
	--kp-ok: #1a7f37;
	--kp-warn: #9a6700;
	--kp-danger: #b32d2e;
	--kp-radius: 10px;
}

/* ---------- Notitser & status ---------- */
.kp-notice,
.kp-status {
	border-radius: var(--kp-radius);
	padding: 14px 18px;
	margin: 0 0 20px;
	font-size: 15px;
	line-height: 1.5;
}
.kp-notice--success { background: #e7f6ec; color: var(--kp-ok); border: 1px solid #b6e2c4; }
.kp-notice--error   { background: #fbeaea; color: var(--kp-danger); border: 1px solid #f1c4c4; }
.kp-status--ok      { background: #e7f6ec; color: var(--kp-ok); border: 1px solid #b6e2c4; }
.kp-status--pending { background: #fdf3e2; color: var(--kp-warn); border: 1px solid #f3deb5; }
.kp-panel {
	background: var(--kp-bg-soft);
	border: 1px solid var(--kp-border);
	border-radius: var(--kp-radius);
	padding: 24px;
}

/* ---------- Formularer ---------- */
.kp-form {
	max-width: 560px;
	background: #fff;
	border: 1px solid var(--kp-border);
	border-radius: var(--kp-radius);
	padding: 28px 30px;
	margin: 0 auto;
}
.kp-form--artwork { max-width: 760px; }
.kp-form h2 { margin-top: 0; }
.kp-form__intro { color: var(--kp-muted); margin-bottom: 20px; }
.kp-form label {
	display: block;
	font-weight: 600;
	margin: 16px 0 6px;
	font-size: 14px;
}
.kp-form input[type="text"],
.kp-form input[type="email"],
.kp-form input[type="password"],
.kp-form input[type="number"],
.kp-form select,
.kp-form textarea {
	width: 100%;
	padding: 11px 12px;
	border: 1px solid var(--kp-border);
	border-radius: 8px;
	font-size: 15px;
	background: #fff;
	box-sizing: border-box;
}
.kp-form input:focus,
.kp-form select:focus,
.kp-form textarea:focus {
	outline: none;
	border-color: var(--kp-accent);
	box-shadow: 0 0 0 3px rgba(31, 58, 95, 0.12);
}
.kp-form__row { display: flex; gap: 18px; }
.kp-form__row > div { flex: 1; }
.kp-checkbox { font-weight: 400 !important; display: flex; align-items: center; gap: 8px; }
.kp-form__alt { margin-top: 18px; color: var(--kp-muted); font-size: 14px; }
.kp-form__actions { display: flex; gap: 12px; align-items: center; margin-top: 24px; }
.kp-help { color: var(--kp-muted); font-size: 13px; margin: 6px 0 0; }

/* ---------- Knapper ---------- */
.kp-btn {
	display: inline-block;
	padding: 11px 20px;
	border: 1px solid var(--kp-border);
	border-radius: 8px;
	background: #fff;
	color: var(--kp-text);
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: background .15s, border-color .15s, transform .05s;
}
.kp-btn:hover { background: var(--kp-bg-soft); }
.kp-btn:active { transform: translateY(1px); }
.kp-btn--primary { background: var(--kp-accent); border-color: var(--kp-accent); color: #fff; }
.kp-btn--primary:hover { background: #16263f; }
.kp-btn--small { padding: 7px 12px; font-size: 13px; }
.kp-btn--danger { color: var(--kp-danger); border-color: #f1c4c4; }
.kp-btn--danger:hover { background: #fbeaea; }

/* ---------- Billedhåndtering ---------- */
.kp-images { display: flex; flex-wrap: wrap; gap: 14px; margin: 8px 0 4px; }
.kp-images__item {
	border: 1px solid var(--kp-border);
	border-radius: 8px;
	padding: 8px;
	text-align: center;
	background: var(--kp-bg-soft);
}
.kp-images__item img { display: block; border-radius: 4px; }
.kp-images__radio,
.kp-images__remove { display: block; font-weight: 400 !important; font-size: 12px; margin: 6px 0 0; }

/* ---------- Dashboard ---------- */
.kp-dashboard__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 18px;
}
.kp-dashboard__head h2 { margin: 0; }
.kp-empty { color: var(--kp-muted); padding: 30px 0; }

/* ---------- Kort & grid ---------- */
.kp-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 24px;
}
.kp-card {
	background: #fff;
	border: 1px solid var(--kp-border);
	border-radius: var(--kp-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow .18s, transform .18s;
}
.kp-card:hover { box-shadow: 0 10px 26px rgba(0,0,0,.10); transform: translateY(-3px); }
.kp-card__link { text-decoration: none; color: inherit; display: flex; flex-direction: column; height: 100%; }
.kp-card__thumb { position: relative; aspect-ratio: 4 / 3; background: var(--kp-bg-soft); overflow: hidden; }
.kp-card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.kp-card:hover .kp-card__thumb img { transform: scale(1.06); }
.kp-card__noimg {
	display: flex; align-items: center; justify-content: center;
	height: 100%; color: var(--kp-muted); font-size: 14px;
}
.kp-card__badge {
	position: absolute; top: 10px; left: 10px;
	background: rgba(31,58,95,.92); color: #fff;
	padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 600;
}
.kp-card__body { padding: 14px 16px; }
.kp-card__title { margin: 0 0 4px; font-size: 17px; }
.kp-card__artist { margin: 0 0 6px; color: var(--kp-muted); font-size: 14px; }
.kp-card__meta { margin: 0; font-weight: 600; color: var(--kp-accent-2); }
.kp-card__actions { display: flex; gap: 8px; align-items: center; margin-top: 12px; }
.kp-card__actions form { margin: 0; }

/* ---------- Galleri-filter ---------- */
.kp-filter { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 26px; }
.kp-filter__btn {
	padding: 8px 16px; border-radius: 999px;
	border: 1px solid var(--kp-border); background: #fff;
	text-decoration: none; color: var(--kp-text); font-size: 14px; font-weight: 600;
}
.kp-filter__btn:hover { background: var(--kp-bg-soft); }
.kp-filter__btn.is-active { background: var(--kp-accent); border-color: var(--kp-accent); color: #fff; }

/* ---------- Responsivt ---------- */
@media (max-width: 600px) {
	.kp-form { padding: 22px 18px; }
	.kp-form__row { flex-direction: column; gap: 0; }
	.kp-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px; }
}
