/**
 * Joerrens UI
 *
 * Shared, dezente UX building blocks for Joerrens plugins.
 * Grayscale first. Color only where it carries real meaning.
 */

:root {
	/* Surfaces */
	--jo-bg:              #ffffff;
	--jo-bg-subtle:       #f5f7f9;
	--jo-bg-muted:        #eef1f4;

	/* Borders */
	--jo-border:          #e5e7eb;
	--jo-border-strong:   #d1d5db;

	/* Text */
	--jo-text:            #111827;
	--jo-text-muted:      #6b7280;
	--jo-text-subtle:     #9ca3af;

	/* Actions */
	--jo-action:          #111827;
	--jo-action-hover:    #374151;

	/* Semantic accents (used sparingly) */
	--jo-success:         #15803d;
	--jo-warning:         #b45309;
	--jo-danger:          #b91c1c;
	--jo-info:            #1d4ed8;

	/* Shape */
	--jo-radius:          6px;
	--jo-radius-lg:       10px;

	/* Spacing */
	--jo-gap-xs:          4px;
	--jo-gap-sm:          8px;
	--jo-gap:             16px;
	--jo-gap-lg:          24px;
	--jo-gap-xl:          32px;

	/* Type */
	--jo-font:            system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	--jo-font-size:       15px;
	--jo-line:            1.5;
}


/* --- Base --- */

.jo {
	font-family: var(--jo-font);
	font-size: var(--jo-font-size);
	line-height: var(--jo-line);
	color: var(--jo-text);
}

.jo-stack > * + * {
	margin-top: var(--jo-gap);
}

.jo-row {
	display: flex;
	gap: var(--jo-gap);
	flex-wrap: wrap;
}

.jo-row > * {
	flex: 1 1 0;
	min-width: 0;
}

.jo-muted {
	color: var(--jo-text-muted);
}

.jo-small {
	font-size: 13px;
}


/* --- Card --- */

.jo-card {
	background: var(--jo-bg);
	border: 1px solid var(--jo-border);
	border-radius: var(--jo-radius-lg);
	padding: var(--jo-gap-lg);
}


/* --- Hinweis / Notice --- */

.jo-notice {
	background: var(--jo-bg-subtle);
	border: 1px solid var(--jo-border);
	border-radius: var(--jo-radius);
	padding: var(--jo-gap);
	color: var(--jo-text);
	font-size: 14px;
}

.jo-notice-title {
	font-weight: 600;
	margin: 0 0 var(--jo-gap-xs);
}

.jo-notice p {
	margin: 0;
}

.jo-notice p + p {
	margin-top: var(--jo-gap-xs);
}

.jo-notice--warning { border-left: 3px solid var(--jo-warning); }
.jo-notice--danger  { border-left: 3px solid var(--jo-danger); }
.jo-notice--success { border-left: 3px solid var(--jo-success); }
.jo-notice--info    { border-left: 3px solid var(--jo-info); }


/* --- Buttons --- */

.jo-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--jo-gap-sm);
	padding: 10px 18px;
	border-radius: var(--jo-radius);
	border: 1px solid var(--jo-action);
	background: var(--jo-action);
	color: #fff;
	font-family: inherit;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	transition: background-color .15s ease, border-color .15s ease;
}

.jo-btn:hover {
	background: var(--jo-action-hover);
	border-color: var(--jo-action-hover);
	color: #fff;
}

.jo-btn--secondary {
	background: var(--jo-bg);
	color: var(--jo-text);
	border-color: var(--jo-border-strong);
}

.jo-btn--secondary:hover {
	background: var(--jo-bg-subtle);
	color: var(--jo-text);
	border-color: var(--jo-border-strong);
}

.jo-btn--ghost {
	background: transparent;
	color: var(--jo-text);
	border-color: transparent;
	padding: 6px 10px;
}

.jo-btn--ghost:hover {
	background: var(--jo-bg-subtle);
	color: var(--jo-text);
}

.jo-btn[disabled],
.jo-btn:disabled {
	opacity: .5;
	cursor: not-allowed;
}


/* --- Badges --- */

.jo-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 3px 10px;
	font-size: 12px;
	font-weight: 500;
	border-radius: 999px;
	background: var(--jo-bg-muted);
	color: var(--jo-text);
	white-space: nowrap;
}

.jo-badge::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--jo-text-muted);
}

.jo-badge--success::before { background: var(--jo-success); }
.jo-badge--warning::before { background: var(--jo-warning); }
.jo-badge--danger::before  { background: var(--jo-danger); }
.jo-badge--info::before    { background: var(--jo-info); }


/* --- Forms --- */

.jo-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.jo-label {
	font-size: 13px;
	font-weight: 500;
	color: var(--jo-text);
}

.jo-label--required::after {
	content: ' *';
	color: var(--jo-danger);
}

.jo-input,
.jo-select,
.jo-textarea {
	padding: 10px 12px;
	border: 1px solid var(--jo-border-strong);
	border-radius: var(--jo-radius);
	background: var(--jo-bg);
	color: var(--jo-text);
	font-family: inherit;
	font-size: 14px;
	line-height: 1.4;
	width: 100%;
	box-sizing: border-box;
	transition: border-color .15s ease, box-shadow .15s ease;
}

.jo-input:focus,
.jo-select:focus,
.jo-textarea:focus {
	outline: none;
	border-color: var(--jo-action);
	box-shadow: 0 0 0 3px rgba(17, 24, 39, .08);
}

.jo-textarea {
	min-height: 100px;
	resize: vertical;
}

.jo-field--error .jo-input,
.jo-field--error .jo-select,
.jo-field--error .jo-textarea {
	border-color: var(--jo-danger);
}

.jo-field-error {
	font-size: 13px;
	color: var(--jo-danger);
}

.jo-checkbox {
	display: flex;
	align-items: flex-start;
	gap: var(--jo-gap-sm);
	font-size: 14px;
	color: var(--jo-text);
}

.jo-checkbox input {
	margin-top: 3px;
}

.jo-checkbox--error {
	color: var(--jo-danger);
}

.jo-checkbox--error input {
	outline: 2px solid var(--jo-danger);
	outline-offset: 2px;
}

.jo-checkbox--required > span::after {
	content: ' *';
	color: var(--jo-danger);
}


/* --- Table --- */

.jo-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.jo-table th,
.jo-table td {
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid var(--jo-border);
	vertical-align: middle;
}

.jo-table th {
	font-weight: 600;
	color: var(--jo-text-muted);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: .02em;
	border-bottom-width: 2px;
}

.jo-table tbody tr:hover {
	background: var(--jo-bg-subtle);
}


/* --- Hidden helper --- */

.jo-hp {
	position: absolute;
	left: -9999px;
	top: -9999px;
	height: 0;
	width: 0;
	overflow: hidden;
}