/* ============================================================
   Bugbert Frontend — Fangmeldung-aligned form system.
   Scoped to .bugbert-app so host themes are not affected.
   Mobile-first, no external fonts, no JS deps.
   ============================================================ */

.bugbert-app {
	/* Fangmeldung blue accent and neutral surfaces */
	--bb-primary:        #0073aa;
	--bb-primary-dark:   #005177;
	--bb-primary-deep:   #005177;
	--bb-light:          #eef2f5;
	--bb-soft:           #f8f9fa;
	--bb-bg:             #f8f9fa;

	/* Neutrals */
	--bb-border:         #dfe6e9;
	--bb-border-input:   #dfe6e9;
	--bb-border-strong:  #cbd5e0;
	--bb-text:           #2c3e50;
	--bb-text-label:     #34495e;
	--bb-text-muted:     #7f8c8d;
	--bb-text-subtle:    #95a5a6;

	/* Shadows */
	--bb-shadow-sm:      0 5px 20px rgba(0, 0, 0, 0.08);
	--bb-shadow-md:      0 8px 24px rgba(0, 0, 0, 0.10);
	--bb-shadow-primary: 0 2px 8px rgba(0, 115, 170, 0.20);

	/* Amber — warnings, "needs attention", "NEU" only */
	--bb-amber:          #d18f1e;
	--bb-amber-bg:       #fff8e6;
	--bb-amber-border:   #f1d99c;
	--bb-amber-text:     #5a4a16;

	/* Danger */
	--bb-danger:         #dc3545;
	--bb-danger-soft:    #fbeaea;
	--bb-danger-border:  #dc3232;

	/* Success / confirmed input */
	--bb-success:        #46b450;
	--bb-success-dark:   #3c763d;
	--bb-success-soft:   #f3faf3;
	--bb-success-border: #bfdfc2;

	/* Info / contextual blue */
	--bb-water:          #0073aa;
	--bb-water-light:    #f0f7fb;
	--bb-water-border:   #b9d9ec;

	/* Radii */
	--bb-radius-sm:      8px;
	--bb-radius-md:      8px;
	--bb-radius-lg:      8px;
	--bb-touch:          44px;

	/* Spacing */
	--bb-1: 4px;
	--bb-2: 8px;
	--bb-3: 12px;
	--bb-4: 16px;
	--bb-5: 20px;
	--bb-6: 28px;
	--bb-7: 40px;

	/* Focus ring */
	--bb-focus:          0 0 0 3px rgba(0, 115, 170, 0.10);

	/* Page container */
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--bb-text);
	background: transparent;
	font-size: 16px;
	line-height: 1.5;
	max-width: 1100px;
	margin: 20px auto;
	padding: 0 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: transparent;
	text-rendering: optimizeLegibility;
}

.bugbert-app *,
.bugbert-app *::before,
.bugbert-app *::after {
	box-sizing: border-box;
}

@media (min-width: 600px) {
	.bugbert-app { padding: 0 20px; }
}

@media (min-width: 992px) {
	.bugbert-app { padding: 0 24px; }
}

/* ---------------- Typography ---------------- */

.bugbert-app h1,
.bugbert-app h2,
.bugbert-app h3 {
	color: var(--bb-text);
	margin: 0;
	line-height: 1.2;
	letter-spacing: 0;
}

.bugbert-app h1 {
	font-size: 1.7rem;
	font-weight: 700;
}

.bugbert-app h2 {
	font-size: 1.35rem;
	font-weight: 700;
}

.bugbert-app h3 {
	font-size: 1rem;
	font-weight: 700;
}

.bugbert-app p { margin: 0 0 var(--bb-3); }
.bugbert-app p:last-child { margin-bottom: 0; }

.bugbert-app a {
	color: var(--bb-primary);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color 120ms ease;
}

.bugbert-app a:hover {
	color: var(--bb-primary-deep);
}

.bugbert-app a:focus-visible {
	outline: none;
	border-radius: 2px;
	box-shadow: var(--bb-focus);
}

/* Small-caps section heading (.bugbert-eyebrow stays as marker class) */
.bugbert-eyebrow {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: uppercase;
	color: var(--bb-text-muted);
}

.bugbert-mono {
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	font-variant-numeric: tabular-nums;
}

/* ---------------- Page header ---------------- */

.bugbert-page-header {
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
	margin-bottom: var(--bb-5);
}

.bugbert-page-header__intro {
	color: var(--bb-text-muted);
	max-width: 60ch;
	font-size: 0.95rem;
}

.bugbert-page-header__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bb-2) var(--bb-4);
	align-items: center;
	margin-top: var(--bb-2);
}

/* ---------------- Cards & surfaces ---------------- */

.bugbert-card {
	background: #fff;
	border: 0;
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	padding: var(--bb-4);
	min-width: 0;
}

@media (hover: hover) and (pointer: fine) {
	.bugbert-card:hover {
		transform: translateY(-1px);
		box-shadow: var(--bb-shadow-md);
	}
}

.bugbert-stack > * + * { margin-top: var(--bb-4); }
.bugbert-stack-lg > * + * { margin-top: var(--bb-6); }

.bugbert-divider {
	height: 1px;
	background: var(--bb-border);
	border: 0;
	margin: var(--bb-5) 0;
}

/* ---------------- Forms ---------------- */

.bugbert-form {
	background: #fff;
	border: 0;
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	padding: var(--bb-5);
	display: flex;
	flex-direction: column;
	gap: var(--bb-4);
	min-width: 0;
}

@media (min-width: 600px) {
	.bugbert-form { padding: var(--bb-6); }
}

.bugbert-form > h2 { margin-bottom: var(--bb-2); }

.bugbert-intro {
	color: var(--bb-text-muted);
	font-size: 0.95rem;
}

.bugbert-field {
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
}

.bugbert-field label,
.bugbert-form > .bugbert-field > label:first-child {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--bb-text-label);
}

.bugbert-app input[type="text"],
.bugbert-app input[type="email"],
.bugbert-app input[type="url"],
.bugbert-app input[type="tel"],
.bugbert-app input[type="number"],
.bugbert-app input[type="password"],
.bugbert-app input[type="search"],
.bugbert-app select,
.bugbert-app textarea {
	font-family: inherit;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--bb-text);
	background: var(--bb-soft);
	border: 1px solid var(--bb-border-input);
	border-radius: var(--bb-radius-md);
	padding: 10px 12px;
	width: 100%;
	min-height: var(--bb-touch);
	transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
	-webkit-tap-highlight-color: transparent;
}

.bugbert-app textarea {
	min-height: 140px;
	resize: vertical;
	line-height: 1.6;
}

.bugbert-app input:hover,
.bugbert-app select:hover,
.bugbert-app textarea:hover {
	background: var(--bb-light);
	border-color: var(--bb-border-strong);
}

.bugbert-app input:focus,
.bugbert-app select:focus,
.bugbert-app textarea:focus {
	outline: none;
	background: #fff;
	border-color: var(--bb-primary);
	box-shadow: var(--bb-focus);
}

.bugbert-app select {
	-webkit-appearance: menulist;
	-moz-appearance: menulist;
	appearance: menulist;
	background-image: none;
	padding-right: 12px;
}

.bugbert-app select option {
	color: var(--bb-text);
	background: #fff;
}

.bugbert-issue-url {
	display: grid;
	gap: var(--bb-2);
}

@media (min-width: 720px) {
	.bugbert-issue-url {
		grid-template-columns: minmax(220px, 0.9fr) minmax(0, 1.1fr);
	}
}

.bugbert-required {
	color: var(--bb-amber);
	margin-left: 2px;
}

.bugbert-form__actions {
	display: flex;
	justify-content: flex-end;
	gap: var(--bb-3);
	flex-wrap: wrap;
}

@media (max-width: 540px) {
	.bugbert-form__actions > .bugbert-button { width: 100%; }
}

/* ---------------- Guided submit wizard ---------------- */

.bugbert-guided-form {
	gap: var(--bb-5);
}

.bugbert-app--guided-submit .bugbert-guided-form {
	background: #fff;
	border: 0;
	box-shadow: var(--bb-shadow-sm);
}

.bugbert-guided-progress {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: var(--bb-2);
	list-style: none;
	margin: 0;
	padding: 0;
}

.bugbert-guided-progress__item {
	min-width: 0;
	color: var(--bb-text-muted);
	font-size: 0.84rem;
	font-weight: 600;
}

.bugbert-guided-progress__button {
	-webkit-appearance: none;
	appearance: none;
	display: flex;
	align-items: center;
	gap: var(--bb-2);
	width: 100%;
	min-width: 0;
	padding: 0;
	border: 0;
	background: transparent;
	color: inherit;
	font: inherit;
	text-align: left;
	cursor: default;
}

.bugbert-guided-progress__item.is-clickable .bugbert-guided-progress__button {
	cursor: pointer;
}

.bugbert-guided-progress__button:disabled {
	opacity: 1;
}

.bugbert-guided-progress__button:focus-visible {
	outline: none;
}

.bugbert-guided-progress__button:focus-visible .bugbert-guided-progress__number {
	box-shadow: var(--bb-focus);
}

.bugbert-guided-progress__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 28px;
	width: 28px;
	height: 28px;
	border-radius: 999px;
	border: 1px solid var(--bb-border-strong);
	background: var(--bb-light);
	color: var(--bb-text-muted);
	font-variant-numeric: tabular-nums;
}

.bugbert-guided-progress__label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bugbert-guided-progress__item.is-active,
.bugbert-guided-progress__item.is-complete {
	color: var(--bb-text);
}

.bugbert-guided-progress__item.is-active .bugbert-guided-progress__number {
	background: var(--bb-primary);
	border-color: var(--bb-primary);
	color: #fff;
	box-shadow: var(--bb-shadow-primary);
}

.bugbert-guided-progress__item.is-complete .bugbert-guided-progress__number {
	background: var(--bb-success);
	border-color: var(--bb-success);
	color: #fff;
}

.bugbert-guided-step {
	display: flex;
	flex-direction: column;
	gap: var(--bb-5);
}

.bugbert-guided-step[hidden],
.bugbert-guided-field[hidden],
.bugbert-guided-field--hidden {
	display: none !important;
}

.bugbert-guided-step__header {
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
}

.bugbert-guided-step__header h1:focus {
	outline: none;
}

.bugbert-guided-step__fields {
	display: grid;
	gap: var(--bb-4);
}

.bugbert-guided-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.bugbert-guided-field__status {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	min-height: 22px;
}

.bugbert-guided-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	width: fit-content;
	border-radius: 999px;
	padding: 2px 9px;
	font-size: 0.72rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0;
}

.bugbert-guided-badge--required {
	background: var(--bb-primary);
	color: #fff;
}

.bugbert-guided-badge--complete {
	display: none;
	background: var(--bb-success);
	color: #fff;
}

.bugbert-guided-field[data-required="1"] > .bugbert-field {
	padding: 14px;
	border: 1px solid var(--bb-water-border);
	border-left: 4px solid var(--bb-primary);
	border-radius: var(--bb-radius-md);
	background: var(--bb-water-light);
	box-shadow: none;
	transition: border-color 150ms ease, background 150ms ease, box-shadow 150ms ease;
}

.bugbert-guided-field[data-required="1"].is-complete > .bugbert-field {
	border-color: var(--bb-success-border);
	border-left-color: var(--bb-success);
	background: var(--bb-success-soft);
	box-shadow: inset 0 0 0 1px rgba(70, 180, 80, 0.08);
}

.bugbert-guided-field[data-required="1"].is-complete input:not([type="radio"]):not([type="checkbox"]):not([type="file"]),
.bugbert-guided-field[data-required="1"].is-complete select,
.bugbert-guided-field[data-required="1"].is-complete textarea {
	border-color: var(--bb-success-border);
	background: #fff;
}

.bugbert-guided-field[data-required="1"].is-complete .bugbert-choice:has(input:checked),
.bugbert-guided-field[data-required="1"].is-complete .bugbert-catch-option:has(.bugbert-catch-option__input:checked) {
	background: var(--bb-success-soft);
	border-color: var(--bb-success);
	color: var(--bb-success-dark);
}

.bugbert-guided-field[data-required="1"].is-complete .bugbert-guided-badge--required {
	display: none;
}

.bugbert-guided-field[data-required="1"].is-complete .bugbert-guided-badge--complete {
	display: inline-flex;
}

.bugbert-guided-field[data-required="1"].is-complete .bugbert-help {
	color: var(--bb-success-dark);
}

.bugbert-guided-field[data-step-key="contact"][data-required="1"].is-complete > .bugbert-field {
	border-color: var(--bb-water-border);
	border-left-color: var(--bb-primary);
	background: var(--bb-water-light);
	box-shadow: none;
}

.bugbert-guided-field[data-step-key="contact"].has-value input:not([type="radio"]):not([type="checkbox"]):not([type="file"]):not(:focus),
.bugbert-guided-field[data-step-key="contact"].has-value select:not(:focus),
.bugbert-guided-field[data-step-key="contact"].has-value textarea:not(:focus) {
	border-color: var(--bb-success);
	background: #fff;
	box-shadow: inset 0 0 0 1px rgba(70, 180, 80, 0.14);
}

.bugbert-guided-field[data-step-key="contact"].has-value .bugbert-choice:has(input:checked),
.bugbert-guided-field[data-step-key="contact"].has-value .bugbert-catch-option:has(.bugbert-catch-option__input:checked),
.bugbert-guided-field[data-step-key="contact"].has-value .bugbert-file__control {
	border-color: var(--bb-success);
	background: #fff;
	box-shadow: inset 0 0 0 1px rgba(70, 180, 80, 0.14);
}

.bugbert-guided-field[data-step-key="contact"][data-required="1"].is-complete .bugbert-help {
	color: var(--bb-text-muted);
}

.bugbert-guided-error {
	border: 1px solid var(--bb-danger-border);
	border-radius: var(--bb-radius-md);
	background: var(--bb-danger-soft);
	color: var(--bb-danger);
	padding: var(--bb-3);
	font-weight: 600;
}

.bugbert-guided-step__actions {
	display: flex;
	flex-direction: column-reverse;
	gap: var(--bb-2);
	align-items: stretch;
}

@media (min-width: 680px) {
	.bugbert-guided-step__fields {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.bugbert-guided-field[data-field-key="bugbert_problem_area"],
	.bugbert-guided-field[data-field-key="bugbert_issue_url"],
	.bugbert-guided-field[data-field-key="bugbert_fangmeldung_reported_catches"],
	.bugbert-guided-field[data-field-key="subject"],
	.bugbert-guided-field[data-field-key="message"],
	.bugbert-guided-field[data-field-key="attachments"] {
		grid-column: 1 / -1;
	}

	.bugbert-guided-step__actions {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
}

.bugbert-app .description,
.bugbert-help {
	font-size: 0.82rem;
	color: var(--bb-text-muted);
	margin: 0;
	line-height: 1.5;
}

/* Choices (radio / checkbox as pill chips) */
.bugbert-choices {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bb-2);
}

.bugbert-choice {
	display: inline-flex;
	align-items: center;
	gap: var(--bb-2);
	padding: 8px 14px;
	min-height: 36px;
	background: var(--bb-soft);
	border: 1px solid var(--bb-border);
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--bb-text);
	cursor: pointer;
	transition: background 150ms ease, border-color 150ms ease, color 150ms ease, transform 120ms ease;
	-webkit-tap-highlight-color: transparent;
}

.bugbert-choice:hover {
	border-color: var(--bb-primary);
	background: var(--bb-light);
}

.bugbert-choice:has(input:checked) {
	background: var(--bb-water-light);
	border-color: var(--bb-primary);
	color: var(--bb-text);
}

.bugbert-choice:active { transform: scale(0.97); }

.bugbert-choice input {
	accent-color: var(--bb-primary);
	margin: 0;
	width: 18px;
	height: 18px;
}

.bugbert-catch-picker {
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
}

.bugbert-catch-picker [hidden],
.bugbert-catch-option--hidden {
	display: none !important;
}

.bugbert-catch-picker__bar {
	display: grid;
	gap: var(--bb-2);
	align-items: start;
}

@media (min-width: 680px) {
	.bugbert-catch-picker__bar {
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: center;
	}
}

.bugbert-catch-picker__count {
	color: var(--bb-text-muted);
	font-size: 0.84rem;
}

.bugbert-catch-picker__search-wrap {
	position: relative;
	min-width: 0;
}

.bugbert-app .bugbert-catch-picker__search {
	padding-right: 40px;
}

.bugbert-catch-picker__clear {
	position: absolute;
	top: 50%;
	right: 8px;
	transform: translateY(-50%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: transparent;
	color: var(--bb-text-muted);
	box-shadow: none;
	font-size: 1.2rem;
	line-height: 1;
	cursor: pointer;
}

.bugbert-catch-picker__clear:hover,
.bugbert-catch-picker__clear:focus-visible {
	background: var(--bb-light);
	color: var(--bb-primary);
	outline: none;
	box-shadow: none;
}

.bugbert-catch-picker__results {
	color: var(--bb-text-muted);
	font-size: 0.82rem;
	margin: 0;
}

.bugbert-catch-picker__list {
	display: grid;
	gap: var(--bb-2);
	max-height: 360px;
	overflow: auto;
	padding: var(--bb-1);
	border: 1px solid var(--bb-border-strong);
	border-radius: var(--bb-radius-md);
	background: var(--bb-bg);
}

.bugbert-catch-option {
	position: relative;
	display: grid;
	grid-template-columns: 24px minmax(0, 1fr);
	gap: var(--bb-1) var(--bb-3);
	align-items: start;
	padding: 12px;
	min-height: 64px;
	background: #fff;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-md);
	color: var(--bb-text);
	cursor: pointer;
	transition: border-color 150ms ease, background 150ms ease, box-shadow 150ms ease;
}

.bugbert-field .bugbert-catch-option {
	font-size: 1rem;
	font-weight: 400;
	color: var(--bb-text);
}

.bugbert-catch-option:hover {
	border-color: var(--bb-primary);
	background: var(--bb-soft);
}

.bugbert-catch-option:has(.bugbert-catch-option__input:checked) {
	background: var(--bb-water-light);
	border-color: var(--bb-primary);
	box-shadow: inset 0 0 0 1px rgba(0, 115, 170, 0.10);
}

.bugbert-catch-option:focus-within {
	border-color: var(--bb-primary);
	box-shadow: var(--bb-focus);
}

.bugbert-catch-option__input {
	grid-column: 1;
	grid-row: 1 / span 2;
	width: 20px;
	height: 20px;
	margin: 2px 0 0;
	accent-color: var(--bb-primary);
}

.bugbert-catch-option__main {
	grid-column: 2;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: var(--bb-1) var(--bb-3);
	align-items: baseline;
	min-width: 0;
}

@media (max-width: 520px) {
	.bugbert-catch-option {
		grid-template-columns: 24px minmax(0, 1fr);
		padding: 12px 10px;
	}

	.bugbert-catch-option__main {
		grid-template-columns: minmax(0, 1fr);
	}
}

.bugbert-catch-option__species {
	font-size: 0.96rem;
	font-weight: 700;
	color: var(--bb-text);
	overflow-wrap: anywhere;
}

.bugbert-catch-option__date {
	font-size: 0.86rem;
	font-weight: 600;
	color: var(--bb-text-muted);
	white-space: nowrap;
}

.bugbert-catch-option__details {
	grid-column: 2;
	color: var(--bb-text-muted);
	font-size: 0.82rem;
	line-height: 1.35;
	overflow-wrap: anywhere;
}

.bugbert-catch-picker__empty {
	color: var(--bb-text-muted);
	font-size: 0.86rem;
	margin: 0;
}

/* File input — dashed dropzone */
.bugbert-file {
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
}

.bugbert-file__control {
	display: flex;
	align-items: center;
	gap: var(--bb-3);
	padding: var(--bb-3) var(--bb-4);
	min-height: var(--bb-touch);
	border: 2px dashed var(--bb-border-strong);
	border-radius: var(--bb-radius-md);
	background: var(--bb-soft);
	color: var(--bb-text-muted);
	cursor: pointer;
	transition: border-color 150ms ease, background 150ms ease, color 150ms ease;
	position: relative;
	-webkit-tap-highlight-color: transparent;
}

.bugbert-file__control:hover,
.bugbert-file__control:focus-within {
	border-color: var(--bb-primary);
	color: var(--bb-primary);
	background: var(--bb-light);
}

.bugbert-file__icon {
	flex: 0 0 auto;
	width: 22px;
	height: 22px;
	border: 1.5px solid currentColor;
	border-radius: 6px;
	position: relative;
}

.bugbert-file__icon::before,
.bugbert-file__icon::after {
	content: "";
	position: absolute;
	background: currentColor;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.bugbert-file__icon::before { width: 10px; height: 1.5px; border-radius: 1px; }
.bugbert-file__icon::after  { width: 1.5px; height: 10px; border-radius: 1px; }

.bugbert-file__label {
	flex: 1;
	font-size: 0.9rem;
	font-weight: 500;
}

.bugbert-app .bugbert-file__control input[type="file"] {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
	width: 100%;
	height: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	min-height: 0;
}

.bugbert-file__selected {
	display: none;
	flex-direction: column;
	gap: var(--bb-1);
	font-size: 0.82rem;
	color: var(--bb-text-muted);
	margin: 0;
	padding: 0;
	list-style: none;
}

.bugbert-file__selected.is-active { display: flex; }

.bugbert-file__selected li {
	display: flex;
	align-items: center;
	gap: var(--bb-2);
	padding: 6px 10px;
	background: var(--bb-soft);
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-sm);
}

/* Buttons */
.bugbert-button,
.bugbert-app button[type="submit"] {
	-webkit-appearance: none;
	appearance: none;
	font: inherit;
	font-weight: 600;
	font-size: 0.95rem;
	color: #fff;
	background: var(--bb-primary);
	border: 1px solid var(--bb-primary);
	border-radius: var(--bb-radius-md);
	padding: 10px 20px;
	min-height: var(--bb-touch);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--bb-2);
	transition: background 150ms ease, border-color 150ms ease, box-shadow 150ms ease, transform 120ms ease;
	box-shadow: var(--bb-shadow-primary);
	line-height: 1.2;
	letter-spacing: 0;
	text-decoration: none;
	-webkit-tap-highlight-color: transparent;
}

.bugbert-button--primary {
	background: var(--bb-primary);
	border-color: var(--bb-primary);
	color: #fff;
}

.bugbert-button:hover,
.bugbert-button--primary:hover,
.bugbert-app .bugbert-form button[type="submit"]:hover {
	background: var(--bb-primary-deep);
	border-color: var(--bb-primary-deep);
	box-shadow: 0 4px 12px rgba(0, 115, 170, 0.24);
}

.bugbert-button:active,
.bugbert-app button[type="submit"]:active {
	transform: scale(0.98);
}

.bugbert-button:focus-visible,
.bugbert-app button[type="submit"]:focus-visible {
	outline: none;
	box-shadow: var(--bb-shadow-primary), var(--bb-focus);
}

.bugbert-button--secondary {
	background: #fff;
	color: var(--bb-primary);
	border-color: var(--bb-border-input);
	box-shadow: none;
}

.bugbert-button--secondary:hover,
.bugbert-button--secondary:focus-visible {
	background: var(--bb-soft);
	border-color: var(--bb-primary);
	color: var(--bb-primary);
}

.bugbert-button--ghost {
	background: var(--bb-soft);
	color: var(--bb-text-muted);
	border-color: var(--bb-border);
	box-shadow: none;
}

.bugbert-button--ghost:hover {
	background: var(--bb-light);
	color: var(--bb-primary);
	border-color: var(--bb-border-input);
	box-shadow: none;
}

.bugbert-button--danger {
	background: #fff;
	color: var(--bb-danger);
	border-color: var(--bb-danger-border);
	box-shadow: none;
}

.bugbert-button--danger:hover {
	background: var(--bb-danger-soft);
	border-color: var(--bb-danger);
	color: var(--bb-danger);
	box-shadow: none;
}

.bugbert-button--small {
	padding: 6px 14px;
	min-height: 36px;
	font-size: 0.85rem;
}

/* Honeypot */
.bugbert-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

/* ---------------- Notices ---------------- */

.bugbert-notice,
.bugbert-success,
.bugbert-error {
	background: var(--bb-water-light);
	color: var(--bb-water);
	border: 1px solid var(--bb-water-border);
	border-radius: var(--bb-radius-md);
	padding: var(--bb-3) var(--bb-4);
	margin: 0 0 var(--bb-4);
	font-size: 0.95rem;
	line-height: 1.5;
}

.bugbert-success {
	background: var(--bb-light);
	color: var(--bb-primary-dark);
	border-color: var(--bb-border-input);
}

.bugbert-error {
	background: var(--bb-danger-soft);
	color: var(--bb-danger);
	border-color: var(--bb-danger-border);
}

.bugbert-notice ul,
.bugbert-success ul,
.bugbert-error ul {
	margin: 0;
	padding-left: 18px;
}

/* ---------------- Success card (after submission) ---------------- */

.bugbert-success-card {
	background: #fff;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	padding: var(--bb-7) var(--bb-5);
	text-align: center;
	position: relative;
	overflow: hidden;
}

.bugbert-success-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(120% 80% at 50% -20%, var(--bb-light), transparent 60%);
	pointer-events: none;
}

.bugbert-success-card__inner {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--bb-4);
}

.bugbert-success-card__seal {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--bb-primary);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
	box-shadow: var(--bb-shadow-primary);
}

.bugbert-success-card__seal::after {
	content: "";
	width: 18px;
	height: 10px;
	border-left: 2.5px solid currentColor;
	border-bottom: 2.5px solid currentColor;
	transform: rotate(-45deg);
	margin-top: -4px;
}

.bugbert-ticket-callout {
	display: inline-flex;
	align-items: center;
	gap: var(--bb-3);
	padding: 10px 16px;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-md);
	background: var(--bb-soft);
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--bb-primary-dark);
	letter-spacing: 0;
}

.bugbert-ticket-callout__hash {
	color: var(--bb-text-muted);
	font-weight: 500;
}

.bugbert-copy {
	-webkit-appearance: none;
	appearance: none;
	font: inherit;
	font-size: 0.7rem;
	font-family: inherit;
	background: #fff;
	color: var(--bb-text-muted);
	border: 1px solid var(--bb-border);
	padding: 4px 10px;
	min-height: 28px;
	border-radius: 999px;
	cursor: pointer;
	transition: all 150ms ease;
	letter-spacing: 0;
	text-transform: uppercase;
	font-weight: 700;
	-webkit-tap-highlight-color: transparent;
}

.bugbert-copy:hover {
	border-color: var(--bb-primary);
	color: var(--bb-primary);
	background: var(--bb-soft);
}

.bugbert-copy.is-copied {
	background: var(--bb-light);
	border-color: var(--bb-primary);
	color: var(--bb-primary-dark);
}

/* ---------------- Pills (status / priority / species) ---------------- */

.bugbert-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 3px 10px 3px 8px;
	border-radius: 999px;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0;
	background: var(--bb-soft);
	color: var(--bb-text-muted);
	border: 1px solid var(--bb-border);
	white-space: nowrap;
	line-height: 1.5;
}

.bugbert-pill::before {
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: currentColor;
	flex: 0 0 auto;
}

.bugbert-pill--status-new,
.bugbert-pill--status-open {
	background: var(--bb-light);
	color: var(--bb-primary-dark);
	border-color: var(--bb-border-input);
}

.bugbert-pill--status-pending,
.bugbert-pill--status-waiting,
.bugbert-pill--status-on_hold {
	background: var(--bb-amber-bg);
	color: var(--bb-amber-text);
	border-color: var(--bb-amber-border);
}

.bugbert-pill--status-resolved {
	background: var(--bb-light);
	color: var(--bb-primary);
	border-color: var(--bb-border-input);
}

.bugbert-pill--status-closed {
	background: var(--bb-soft);
	color: var(--bb-text-muted);
	border-color: var(--bb-border);
}

.bugbert-pill--priority-low {
	background: var(--bb-soft);
	color: var(--bb-text-muted);
	border-color: var(--bb-border);
}

.bugbert-pill--priority-normal {
	background: var(--bb-water-light);
	color: var(--bb-water);
	border-color: var(--bb-water-border);
}

.bugbert-pill--priority-high {
	background: var(--bb-amber-bg);
	color: var(--bb-amber-text);
	border-color: var(--bb-amber-border);
}

.bugbert-pill--priority-urgent {
	background: var(--bb-danger-soft);
	color: var(--bb-danger);
	border-color: var(--bb-danger-border);
}

/* ---------------- Ticket id ---------------- */

.bugbert-ticket-id {
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--bb-primary-dark);
	letter-spacing: 0;
	text-decoration: none;
	display: inline-flex;
	align-items: baseline;
	gap: 2px;
}

.bugbert-ticket-id__hash {
	color: var(--bb-text-muted);
	font-weight: 500;
}

a.bugbert-ticket-id { color: var(--bb-primary-dark); }
a.bugbert-ticket-id:hover { color: var(--bb-primary); }

/* ---------------- Tables that become cards ---------------- */

.bugbert-ticket-list {
	background: transparent;
	min-width: 0;
}

.bugbert-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	background: #fff;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	overflow: hidden;
	min-width: 0;
}

.bugbert-table thead { background: var(--bb-soft); }

.bugbert-table th {
	font-size: 0.72rem;
	letter-spacing: 0;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--bb-text-muted);
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid var(--bb-border);
}

.bugbert-table td {
	padding: 10px 12px;
	font-size: 0.9rem;
	color: var(--bb-text);
	border-bottom: 1px solid var(--bb-border);
	vertical-align: middle;
}

.bugbert-table tr:last-child td { border-bottom: 0; }

.bugbert-table td strong { color: var(--bb-primary); }

@media (hover: hover) and (pointer: fine) {
	.bugbert-table tbody tr:hover td { background: var(--bb-soft); }
}

.bugbert-table td:first-child {
	width: 1%;
	white-space: nowrap;
}

.bugbert-table .bugbert-cell-subject {
	font-weight: 500;
	color: var(--bb-primary-dark);
	max-width: 380px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bugbert-table .bugbert-cell-muted {
	color: var(--bb-text-muted);
	font-size: 0.82rem;
}

/* Table -> card grid on mobile */
@media (max-width: 720px) {
	.bugbert-table,
	.bugbert-table tbody,
	.bugbert-table tr,
	.bugbert-table td {
		display: block;
		width: 100%;
	}

	.bugbert-table {
		border: 0;
		background: transparent;
		border-radius: 0;
		overflow: visible;
		box-shadow: none;
	}

	.bugbert-table thead { display: none; }

	.bugbert-table tr {
		background: #fff;
		border: 1px solid var(--bb-border);
		border-left: 3px solid var(--bb-primary);
		border-radius: var(--bb-radius-lg);
		box-shadow: var(--bb-shadow-sm);
		padding: var(--bb-3) var(--bb-4);
		margin-bottom: var(--bb-3);
		display: grid;
		grid-template-columns: auto minmax(0, 1fr);
		gap: var(--bb-2) var(--bb-3);
	}

	.bugbert-table tbody tr:hover td { background: transparent; }

	.bugbert-table td {
		border: 0;
		padding: 0;
		font-size: 0.9rem;
		white-space: normal;
		max-width: none;
		overflow: visible;
		text-overflow: clip;
		min-width: 0;
	}

	.bugbert-table td::before {
		content: attr(data-label);
		display: block;
		font-size: 0.7rem;
		letter-spacing: 0;
		text-transform: uppercase;
		color: var(--bb-text-muted);
		font-weight: 700;
		margin-bottom: 2px;
	}

	.bugbert-table td[data-label="hidden"]::before { display: none; }

	/* Featured row: ticket id + subject on top, the rest beneath */
	.bugbert-table td:first-child,
	.bugbert-table td:nth-child(2) {
		grid-column: 1 / -1;
	}

	.bugbert-table .bugbert-cell-subject {
		font-size: 1.05rem;
		font-weight: 700;
		color: var(--bb-primary-dark);
		max-width: none;
		overflow: visible;
		text-overflow: clip;
		white-space: normal;
		line-height: 1.3;
	}
}

/* ---------------- Empty state ---------------- */

.bugbert-empty {
	background: #fff;
	border: 1px dashed var(--bb-border-input);
	border-radius: var(--bb-radius-lg);
	padding: var(--bb-7) var(--bb-5);
	text-align: center;
	color: var(--bb-text-muted);
}

.bugbert-empty__title {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--bb-primary-dark);
	margin: 0 0 var(--bb-2);
}

/* ---------------- Pagination ---------------- */

.bugbert-pagination {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 4px;
	padding: 4px;
	margin-top: var(--bb-4);
	background: #fff;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	font-size: 0.9rem;
}

.bugbert-pagination a,
.bugbert-pagination strong {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	min-height: 36px;
	padding: 6px 14px;
	border-radius: var(--bb-radius-md);
	text-decoration: none;
	color: var(--bb-text-muted);
	border: 0;
	font-weight: 600;
	background: transparent;
	transition: background 150ms ease, color 150ms ease, transform 120ms ease;
	-webkit-tap-highlight-color: transparent;
}

.bugbert-pagination a:hover {
	background: var(--bb-soft);
	color: var(--bb-primary-dark);
}

.bugbert-pagination a:active { transform: scale(0.97); }

.bugbert-pagination strong {
	background: var(--bb-primary);
	color: #fff;
	box-shadow: var(--bb-shadow-primary);
}

/* ---------------- Detail view ---------------- */

.bugbert-ticket-detail {
	display: flex;
	flex-direction: column;
	gap: var(--bb-5);
}

.bugbert-detail-header {
	display: flex;
	flex-direction: column;
	gap: var(--bb-3);
	padding-bottom: var(--bb-4);
	border-bottom: 1px solid var(--bb-border);
}

.bugbert-detail-header__top {
	display: flex;
	align-items: center;
	gap: var(--bb-2);
	flex-wrap: wrap;
}

.bugbert-detail-header__subject {
	font-size: 1.7rem;
	font-weight: 700;
	color: var(--bb-text);
	line-height: 1.2;
	letter-spacing: 0;
	margin: 0;
}

.bugbert-detail-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bb-2) var(--bb-5);
	font-size: 0.85rem;
	color: var(--bb-text-muted);
}

.bugbert-detail-meta__item {
	display: inline-flex;
	align-items: center;
	gap: var(--bb-2);
}

.bugbert-detail-meta__label {
	font-size: 0.7rem;
	letter-spacing: 0;
	text-transform: uppercase;
	color: var(--bb-text-muted);
	font-weight: 700;
}

/* Staff ticket workspace */
.bugbert-staff-workspace {
	display: flex;
	flex-direction: column;
	gap: var(--bb-5);
	min-width: 0;
}

.bugbert-staff-header {
	gap: var(--bb-4);
}

.bugbert-staff-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bb-2);
	align-items: center;
}

.bugbert-staff-grid {
	display: grid;
	gap: var(--bb-4);
	align-items: start;
}

@media (min-width: 860px) {
	.bugbert-staff-grid {
		grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
	}
}

.bugbert-staff-panel,
.bugbert-staff-section {
	background: #fff;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	padding: var(--bb-4);
	min-width: 0;
}

.bugbert-staff-section {
	display: flex;
	flex-direction: column;
	gap: var(--bb-4);
}

.bugbert-staff-panel__header,
.bugbert-staff-section__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--bb-3);
	margin-bottom: var(--bb-3);
}

.bugbert-staff-section__header {
	margin-bottom: 0;
}

.bugbert-staff-panel__header h2,
.bugbert-staff-section__header h2 {
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0;
}

.bugbert-staff-action-form {
	display: flex;
	flex-direction: column;
	gap: var(--bb-4);
}

.bugbert-staff-fields {
	display: grid;
	gap: var(--bb-3);
}

@media (min-width: 620px) {
	.bugbert-staff-fields {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.bugbert-staff-check {
	display: inline-flex;
	align-items: center;
	gap: var(--bb-2);
	font-weight: 600;
	color: var(--bb-primary-dark);
	min-height: var(--bb-touch);
}

.bugbert-staff-check input {
	width: 18px;
	height: 18px;
	accent-color: var(--bb-primary);
}

.bugbert-staff-dl {
	display: grid;
	gap: var(--bb-2) var(--bb-4);
	margin: 0;
}

@media (min-width: 620px) {
	.bugbert-staff-dl {
		grid-template-columns: minmax(120px, 0.42fr) minmax(0, 1fr);
	}
}

.bugbert-staff-dl dt {
	color: var(--bb-text-muted);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: uppercase;
}

.bugbert-staff-dl dd {
	margin: 0;
	min-width: 0;
	overflow-wrap: anywhere;
}

.bugbert-staff-composer-grid {
	display: flex;
	flex-direction: column;
	gap: var(--bb-4);
}

.bugbert-staff-composer {
	box-shadow: none;
	width: 100%;
}

.bugbert-staff-composer .bugbert-editor__area {
	min-height: 280px;
}

.bugbert-staff-composer--internal {
	background: var(--bb-amber-bg);
	border-color: var(--bb-amber-border);
	padding: var(--bb-4);
	gap: var(--bb-2);
}

.bugbert-staff-composer--internal .bugbert-composer__title {
	font-size: 0.85rem;
}

.bugbert-staff-composer--internal .bugbert-editor__area {
	min-height: 120px;
	max-height: 240px;
}

.bugbert-staff-composer--internal .bugbert-editor__toolbar {
	padding: 4px;
}

.bugbert-staff-composer--internal .bugbert-editor__btn {
	min-width: 28px;
	height: 28px;
	font-size: 0.8rem;
}

.bugbert-staff-table td:first-child {
	font-weight: 700;
	color: var(--bb-primary-dark);
}

.bugbert-staff-table td,
.bugbert-staff-table th {
	vertical-align: top;
}

/* Thread */
.bugbert-thread {
	display: flex;
	flex-direction: column;
	gap: var(--bb-3);
	min-width: 0;
}

.bugbert-message {
	position: relative;
	display: grid;
	grid-template-columns: 36px minmax(0, 1fr);
	gap: var(--bb-3);
	background: #fff;
	border: 1px solid var(--bb-border);
	border-left: 3px solid var(--bb-border-input);
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	padding: var(--bb-4);
	min-width: 0;
}

.bugbert-message__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--bb-soft);
	color: var(--bb-primary-dark);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 0.85rem;
	letter-spacing: 0;
	border: 1px solid var(--bb-border);
	flex: 0 0 auto;
	text-transform: uppercase;
}

.bugbert-message--customer {
	border-left-color: var(--bb-water);
}

.bugbert-message--customer .bugbert-message__avatar {
	background: var(--bb-water-light);
	color: var(--bb-water);
	border-color: var(--bb-water-border);
}

.bugbert-message--staff {
	background: var(--bb-soft);
	border-color: var(--bb-border-input);
	border-left-color: var(--bb-primary);
}

.bugbert-message--staff .bugbert-message__avatar {
	background: var(--bb-primary);
	color: #fff;
	border-color: var(--bb-primary);
}

.bugbert-message--internal {
	background: linear-gradient(180deg, var(--bb-amber-bg) 0%, #fff 70%);
	border-color: var(--bb-amber-border);
	border-left-color: var(--bb-amber);
}

.bugbert-message--internal .bugbert-message__avatar {
	background: var(--bb-amber);
	color: #fff;
	border-color: var(--bb-amber);
}

.bugbert-message__main {
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
	min-width: 0;
}

.bugbert-message__header {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--bb-2) var(--bb-3);
	font-size: 0.85rem;
	color: var(--bb-text-muted);
}

.bugbert-message__author {
	font-weight: 700;
	color: var(--bb-primary-dark);
	font-size: 0.92rem;
}

.bugbert-message__date {
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	font-size: 0.78rem;
	color: var(--bb-text-muted);
}

.bugbert-message__badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: uppercase;
	padding: 2px 8px;
	border-radius: 999px;
	background: var(--bb-amber);
	color: #fff;
}

.bugbert-message__body {
	color: var(--bb-text);
	font-size: 0.95rem;
	line-height: 1.6;
	overflow-wrap: anywhere;
	min-width: 0;
}

.bugbert-message__body p:first-child { margin-top: 0; }
.bugbert-message__body p:last-child { margin-bottom: 0; }

.bugbert-message__body a {
	color: var(--bb-primary);
}

.bugbert-attachments {
	list-style: none;
	margin: 0;
	padding: var(--bb-3) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--bb-1);
	border-top: 1px dashed var(--bb-border);
}

.bugbert-attachments li {
	display: flex;
	align-items: center;
	gap: var(--bb-2);
	font-size: 0.82rem;
	color: var(--bb-text-muted);
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

.bugbert-attachments li::before {
	content: "";
	width: 12px;
	height: 14px;
	border: 1px solid currentColor;
	border-radius: 2px;
	flex: 0 0 auto;
	position: relative;
	background:
		linear-gradient(to right, currentColor 0, currentColor 100%) no-repeat 2px 4px / 6px 1px,
		linear-gradient(to right, currentColor 0, currentColor 100%) no-repeat 2px 7px / 6px 1px;
}

.bugbert-attachments__size {
	color: var(--bb-text-muted);
	font-size: 0.7rem;
}

/* Composer */
.bugbert-composer {
	background: #fff;
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-lg);
	box-shadow: var(--bb-shadow-sm);
	padding: var(--bb-5);
	display: flex;
	flex-direction: column;
	gap: var(--bb-3);
	min-width: 0;
}

.bugbert-composer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--bb-3);
}

.bugbert-composer__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--bb-primary-dark);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0;
}

.bugbert-composer textarea {
	min-height: 120px;
	resize: vertical;
}

.bugbert-composer__actions {
	display: flex;
	justify-content: flex-end;
	gap: var(--bb-2);
}

/* ---------------- Fieldsets (legacy) ---------------- */

.bugbert-app fieldset {
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-md);
	padding: var(--bb-3) var(--bb-4);
	margin: 0;
	background: #fff;
}

.bugbert-app legend {
	padding: 0 var(--bb-2);
	font-weight: 700;
	color: var(--bb-primary-dark);
	font-size: 0.78rem;
	letter-spacing: 0;
	text-transform: uppercase;
}

.bugbert-app .bugbert-form table { width: 100%; }

/* ---------------- Subtle entrance motion ---------------- */

@keyframes bbFadeUp {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

.bugbert-app .bugbert-message,
.bugbert-app .bugbert-table tr,
.bugbert-app .bugbert-success-card,
.bugbert-app .bugbert-form,
.bugbert-app .bugbert-empty,
.bugbert-app .bugbert-composer {
	animation: bbFadeUp 0.4s ease-out both;
}

.bugbert-app .bugbert-message:nth-child(2) { animation-delay: 0.05s; }
.bugbert-app .bugbert-message:nth-child(3) { animation-delay: 0.10s; }
.bugbert-app .bugbert-message:nth-child(4) { animation-delay: 0.15s; }

/* ---------------- Reduced motion ---------------- */

@media (prefers-reduced-motion: reduce) {
	.bugbert-app *,
	.bugbert-app *::before,
	.bugbert-app *::after {
		animation: none !important;
		transition: none !important;
	}
}

/* ---------------- Smaller screens ---------------- */

@media (max-width: 540px) {
	.bugbert-app { margin: 12px auto; }

	.bugbert-form,
	.bugbert-success-card,
	.bugbert-composer,
	.bugbert-card {
		padding: var(--bb-4);
	}

	.bugbert-staff-toolbar > .bugbert-button,
	.bugbert-staff-panel .bugbert-form__actions > .bugbert-button,
	.bugbert-staff-section .bugbert-form__actions > .bugbert-button,
	.bugbert-staff-composer .bugbert-composer__actions > .bugbert-button {
		width: 100%;
	}

	.bugbert-staff-panel,
	.bugbert-staff-section {
		padding: var(--bb-4);
	}

	.bugbert-success-card { padding-top: var(--bb-6); }

	.bugbert-message {
		padding: var(--bb-3);
		grid-template-columns: 32px minmax(0, 1fr);
		gap: var(--bb-2);
	}

	.bugbert-message__avatar {
		width: 32px;
		height: 32px;
		font-size: 0.78rem;
	}
}

/* ---------------- Rich text editor (Squire) ---------------- */
.bugbert-editor {
	display: flex;
	flex-direction: column;
	border: 1px solid var(--bb-border-input);
	border-radius: 12px;
	background: #fff;
	overflow: hidden;
}

.bugbert-editor:focus-within {
	border-color: var(--bb-primary);
	box-shadow: var(--bb-focus);
}

.bugbert-editor__toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 2px;
	padding: 6px;
	background: var(--bb-soft);
	border-bottom: 1px solid var(--bb-border-input);
}

.bugbert-editor__btn {
	-webkit-appearance: none;
	appearance: none;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 6px;
	color: var(--bb-primary-dark);
	cursor: pointer;
	font: inherit;
	font-size: 0.85rem;
	min-width: 32px;
	height: 32px;
	padding: 0 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	transition: background 120ms ease, border-color 120ms ease;
}

.bugbert-editor__btn:hover {
	background: #fff;
	border-color: var(--bb-border-input);
}

.bugbert-editor__btn:focus-visible {
	outline: none;
	border-color: var(--bb-primary);
	box-shadow: var(--bb-focus);
}

.bugbert-editor__btn[aria-pressed="true"] {
	background: #fff;
	border-color: var(--bb-primary);
	color: var(--bb-primary-dark);
}

.bugbert-editor__btn--bold { font-weight: 700; }
.bugbert-editor__btn--italic { font-style: italic; }
.bugbert-editor__btn--underline { text-decoration: underline; }
.bugbert-editor__btn--strike { text-decoration: line-through; }

.bugbert-editor__sep {
	width: 1px;
	margin: 4px 4px;
	background: var(--bb-border-input);
}

.bugbert-editor__area {
	min-height: 160px;
	max-height: 480px;
	overflow-y: auto;
	padding: 12px 14px;
	font: inherit;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--bb-text);
	outline: none;
}

.bugbert-editor__area:empty::before {
	content: attr(data-placeholder);
	color: var(--bb-text-muted);
	pointer-events: none;
}

.bugbert-editor__area p,
.bugbert-editor__area div {
	margin: 0 0 0.4em;
}

.bugbert-editor__area ul,
.bugbert-editor__area ol {
	margin: 0 0 0.6em;
	padding-left: 1.4em;
}

.bugbert-editor__area blockquote {
	margin: 0 0 0.6em;
	padding: 4px 10px;
	border-left: 3px solid var(--bb-border-input);
	color: var(--bb-text-muted);
}

.bugbert-editor__area a {
	color: var(--bb-primary);
}

.bugbert-app .bugbert-editor__hidden {
	display: none !important;
}

/* ---------------- Message details panel ---------------- */
.bugbert-message__channel {
	margin-left: auto;
	font-size: 0.7rem;
	letter-spacing: 0;
	text-transform: uppercase;
	color: var(--bb-text-muted);
	font-weight: 600;
	padding: 2px 8px;
	background: var(--bb-soft);
	border-radius: 999px;
}

.bugbert-message__details {
	margin-top: var(--bb-3);
	border-top: 1px solid var(--bb-border);
	padding-top: var(--bb-2);
}

.bugbert-message__details-toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--bb-text-muted);
	padding: 4px 8px;
	margin-left: -8px;
	border-radius: 6px;
	list-style: none;
	user-select: none;
	transition: background 120ms ease, color 120ms ease;
}

.bugbert-message__details-toggle::-webkit-details-marker { display: none; }

.bugbert-message__details-toggle:hover,
.bugbert-message__details-toggle:focus-visible {
	background: var(--bb-soft);
	color: var(--bb-primary-dark);
	outline: none;
}

.bugbert-message__details-icon {
	display: inline-block;
	transition: transform 120ms ease;
	font-size: 0.9rem;
	line-height: 1;
}

.bugbert-message__details[open] > .bugbert-message__details-toggle .bugbert-message__details-icon {
	transform: rotate(90deg);
}

.bugbert-message__details-body {
	margin-top: var(--bb-2);
	display: flex;
	flex-direction: column;
	gap: var(--bb-3);
	background: var(--bb-soft);
	border: 1px solid var(--bb-border);
	border-radius: var(--bb-radius-md);
	padding: var(--bb-3);
}

.bugbert-message__details-section h4 {
	margin: 0 0 6px;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0;
	color: var(--bb-primary-dark);
}

.bugbert-meta-grid {
	display: grid;
	grid-template-columns: minmax(110px, 0.4fr) minmax(0, 1fr);
	gap: 4px var(--bb-3);
	margin: 0;
	font-size: 0.82rem;
}

.bugbert-meta-grid dt {
	color: var(--bb-text-muted);
	font-weight: 600;
}

.bugbert-meta-grid dd {
	margin: 0;
	min-width: 0;
	overflow-wrap: anywhere;
	color: var(--bb-text);
}

.bugbert-meta-grid code {
	background: #fff;
	border: 1px solid var(--bb-border-input);
	border-radius: 4px;
	padding: 1px 6px;
	font-size: 0.8rem;
	display: inline-block;
	max-width: 100%;
	overflow-wrap: anywhere;
}

.bugbert-meta-grid__wrap {
	display: block;
	white-space: pre-wrap;
	word-break: break-all;
	line-height: 1.5;
}

.bugbert-message__details-pre {
	margin: 0;
	padding: var(--bb-2);
	background: #fff;
	border: 1px solid var(--bb-border-input);
	border-radius: var(--bb-radius-md);
	font-size: 0.78rem;
	line-height: 1.5;
	max-height: 320px;
	overflow: auto;
	white-space: pre-wrap;
	word-break: break-word;
	color: var(--bb-text);
}

.bugbert-message__delivery-log {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--bb-2);
}

.bugbert-message__delivery-entry {
	background: #fff;
	border: 1px solid var(--bb-border-input);
	border-left: 3px solid var(--bb-border-input);
	border-radius: var(--bb-radius-md);
	padding: 8px 10px;
}

.bugbert-message__delivery-entry--ok {
	border-left-color: var(--bb-primary);
}

.bugbert-message__delivery-entry--fail {
	border-left-color: var(--bb-danger);
}

.bugbert-message__delivery-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--bb-2);
	font-size: 0.78rem;
	margin-bottom: 4px;
}

.bugbert-message__delivery-status {
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0;
	color: var(--bb-primary-dark);
}

.bugbert-message__delivery-entry--fail .bugbert-message__delivery-status {
	color: var(--bb-danger);
}

.bugbert-message__delivery-head time {
	color: var(--bb-text-muted);
	font-variant-numeric: tabular-nums;
}

.bugbert-message__details-nested {
	margin-top: 6px;
	font-size: 0.78rem;
}

.bugbert-message__details-nested summary {
	cursor: pointer;
	color: var(--bb-text-muted);
	padding: 4px 0;
}

.bugbert-message__details-nested summary:hover {
	color: var(--bb-primary-dark);
}

/* ---------------- Image gallery + lightbox ---------------- */
.bugbert-attachments-gallery {
	list-style: none;
	padding: 0;
	margin: var(--bb-3) 0 0;
	display: grid;
	gap: var(--bb-2);
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

.bugbert-attachments-gallery li {
	margin: 0;
}

.bugbert-attachments-gallery__item {
	display: flex;
	flex-direction: column;
	gap: 4px;
	background: var(--bb-soft);
	border: 1px solid var(--bb-border-input);
	border-radius: 10px;
	overflow: hidden;
	padding: 0;
	text-decoration: none;
	color: var(--bb-text);
	cursor: zoom-in;
	transition: border-color 120ms ease, transform 120ms ease, box-shadow 120ms ease;
}

.bugbert-attachments-gallery__item:hover,
.bugbert-attachments-gallery__item:focus-visible {
	border-color: var(--bb-primary);
	box-shadow: var(--bb-shadow-sm);
	transform: translateY(-1px);
	outline: none;
}

.bugbert-attachments-gallery__item img {
	display: block;
	width: 100%;
	height: 120px;
	object-fit: cover;
	background: #fff;
}

.bugbert-attachments-gallery__caption {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 6px 10px 8px;
	font-size: 0.78rem;
}

.bugbert-attachments-gallery__name {
	font-weight: 600;
	color: var(--bb-primary-dark);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

body.bugbert-lightbox-open {
	overflow: hidden;
}

.bugbert-lightbox {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: bbFadeIn 0.15s ease-out;
}

.bugbert-lightbox[hidden] { display: none; }

.bugbert-lightbox__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 25, 14, 0.88);
	cursor: zoom-out;
}

.bugbert-lightbox__stage {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--bb-2);
	max-width: 96vw;
	max-height: 96vh;
	width: auto;
	z-index: 1;
}

.bugbert-lightbox__toolbar {
	display: flex;
	align-items: center;
	gap: var(--bb-2);
	color: #fff;
	font-size: 0.85rem;
	width: 100%;
	min-height: 36px;
}

.bugbert-lightbox__caption {
	flex: 1 1 auto;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	opacity: 0.9;
}

.bugbert-lightbox__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.18);
	color: #fff;
	text-decoration: none;
	font-size: 1.1rem;
	line-height: 1;
	cursor: pointer;
	transition: background 120ms ease, border-color 120ms ease;
}

.bugbert-lightbox__btn:hover,
.bugbert-lightbox__btn:focus-visible {
	background: rgba(255, 255, 255, 0.22);
	border-color: rgba(255, 255, 255, 0.32);
	outline: none;
}

.bugbert-lightbox__figure {
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 100%;
	max-height: calc(96vh - 60px);
}

.bugbert-lightbox__figure img {
	max-width: 100%;
	max-height: calc(96vh - 60px);
	display: block;
	background: #1a1a1a;
	border-radius: 8px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.bugbert-lightbox__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(0, 0, 0, 0.4);
	color: #fff;
	font-size: 1.6rem;
	line-height: 1;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.bugbert-lightbox__nav[hidden] { display: none; }

.bugbert-lightbox__nav:hover,
.bugbert-lightbox__nav:focus-visible {
	background: rgba(0, 0, 0, 0.65);
	outline: none;
}

.bugbert-lightbox__nav--prev { left: -56px; }
.bugbert-lightbox__nav--next { right: -56px; }

@media (max-width: 720px) {
	.bugbert-lightbox__nav--prev { left: 4px; }
	.bugbert-lightbox__nav--next { right: 4px; }
}

@keyframes bbFadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}
