.sba-board,
.sba-update-form {
	border: 1px solid rgba(0,0,0,.1);
	border-radius: 16px;
	padding: clamp(20px, 4vw, 34px);
	background: #fffdf8;
	margin: 24px 0;
}
.sba-board-heading {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	align-items: baseline;
	flex-wrap: wrap;
	border-bottom: 1px solid rgba(0,0,0,.08);
	padding-bottom: 12px;
	margin-bottom: 18px;
}
.sba-board-heading h2 { margin: 0; }
.sba-last-updated { opacity: .72; margin: 0; font-size: .95rem; }
.sba-harvest-note {
	font-size: 1.02rem;
	border-left: 4px solid currentColor;
	padding-left: 16px;
	margin: 18px 0 24px;
}
.sba-public-groups { display: grid; gap: 18px; }
.sba-public-group {
	background: #fff;
	border: 1px solid rgba(0,0,0,.08);
	border-radius: 14px;
	padding: 0;
	overflow: hidden;
}
.sba-public-group-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 13px 16px 10px;
	background: rgba(0,0,0,.025);
	border-bottom: 1px solid rgba(0,0,0,.07);
}
.sba-public-group-header h3 {
	font-size: clamp(1.08rem, 2vw, 1.28rem);
	margin: 0;
	letter-spacing: .01em;
}
.sba-public-group-unavailable .sba-public-group-header,
.sba-public-group-coming-soon .sba-public-group-header {
	background: rgba(0,0,0,.035);
}
.sba-availability-table {
	width: 100%;
	table-layout: auto;
	border-collapse: collapse;
	margin: 0;
	font-size: .98rem;
}
.sba-availability-table tr + tr { border-top: 1px solid rgba(0,0,0,.065); }
.sba-availability-table td {
	padding: 10px 16px;
	vertical-align: middle;
}
.sba-product-name {
	font-weight: 700;
	width: var(--sba-name-col-width, 1%);
	white-space: nowrap;
}
.sba-product-name a { text-decoration: none; }
.sba-product-name a:hover { text-decoration: underline; }
.sba-product-status {
	width: auto;
	text-align: left;
	white-space: nowrap;
}
.sba-product-action { width: var(--sba-action-col-width, 1%); text-align: right; font-weight: 700; white-space: nowrap; font-size: .93rem; }
.sba-product-action a { text-decoration: none; }
.sba-product-action a:hover { text-decoration: underline; }
.sba-product-action span { opacity: .74; font-weight: 700; }
.sba-status-pill {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	max-width: none;
	border: 1px solid rgba(0,0,0,.14);
	border-radius: 999px;
	padding: 4px 9px;
	font-size: .82rem;
	font-weight: 800;
	line-height: 1.1;
	white-space: nowrap;
	background: rgba(0,0,0,.035);
}
.sba-status-available .sba-status-pill,
.sba-status-pill.sba-status-available { background: rgba(72, 126, 78, .10); }
.sba-status-limited .sba-status-pill,
.sba-status-pill.sba-status-limited { background: rgba(180, 115, 25, .12); }
.sba-status-coming_soon .sba-status-pill,
.sba-status-pill.sba-status-coming_soon { background: rgba(83, 118, 164, .12); }
.sba-status-market_pickup_only .sba-status-pill,
.sba-status-pill.sba-status-market_pickup_only,
.sba-status-by_request .sba-status-pill,
.sba-status-pill.sba-status-by_request { background: rgba(93, 73, 52, .10); }
.sba-status-unavailable .sba-status-pill,
.sba-status-sold_out .sba-status-pill,
.sba-status-not_this_year .sba-status-pill,
.sba-status-pill.sba-status-unavailable,
.sba-status-pill.sba-status-sold_out,
.sba-status-pill.sba-status-not_this_year { background: rgba(0,0,0,.06); }
.sba-group-summary {
	margin: 0;
	padding: 11px 16px 14px;
	font-size: .95rem;
	line-height: 1.5;
	opacity: .82;
	background: rgba(0,0,0,.018);
	border-top: 1px solid rgba(0,0,0,.055);
}
.sba-board-groups { display: grid; gap: 22px; }
.sba-board-group h3,
.sba-form-group-title { margin-top: 28px; }
.sba-board-items { display: grid; gap: 12px; }
.sba-board-item,
.sba-prompt-card {
	background: #fff;
	border: 1px solid rgba(0,0,0,.08);
	border-radius: 12px;
	padding: 14px 16px;
}
.sba-prompt-category {
	border-color: rgba(0,0,0,.18);
	background: rgba(0,0,0,.025);
}
.sba-prompt-product {
	margin-left: clamp(0px, 2vw, 20px);
}
.sba-disabled-by-category {
	opacity: .45;
	background: rgba(0,0,0,.035);
}
.sba-disabled-by-category:before {
	content: "Disabled because the category is marked unavailable.";
	display: block;
	font-size: .85rem;
	font-weight: 700;
	margin-bottom: 8px;
	opacity: .75;
}
.sba-board-item-main {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	align-items: baseline;
}
.sba-board-item-main span {
	font-weight: 700;
	white-space: nowrap;
}
.sba-board-item p { margin: 8px 0 0; opacity: .85; }
.sba-board-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.sba-button {
	display: inline-block;
	padding: 11px 18px;
	border-radius: 999px;
	text-decoration: none;
	border: 1px solid currentColor;
	font-weight: 700;
	cursor: pointer;
	background: #2d241b;
	color: #fff;
}
.sba-button:hover { opacity: .9; color: #fff; }
.sba-button-secondary { background: transparent; color: inherit; }
.sba-button-secondary:hover { color: inherit; }
.sba-form-intro { max-width: 720px; }
.sba-full-label,
.sba-prompt-card label { display: block; font-weight: 700; }
.sba-update-form textarea,
.sba-update-form input[type="text"],
.sba-update-form select {
	width: 100%;
	margin-top: 6px;
	border-radius: 8px;
}
.sba-update-form select {
	min-height: 42px;
}
.sba-helper { opacity: .78; margin-top: -4px; }
.sba-status-select {
	font-weight: 700;
	background: #fffdf8;
}
.sba-submit { margin-top: 22px; }
.sba-success {
	background: #e8f5ee;
	border: 1px solid #b7dec9;
	padding: 12px 14px;
	border-radius: 10px;
	margin-bottom: 16px;
}
@media (max-width: 700px) {
	.sba-board-item-main { display: block; }
	.sba-prompt-product { margin-left: 0; }
	.sba-public-group-header { padding: 12px 13px 9px; }
	.sba-availability-table,
	.sba-availability-table tbody,
	.sba-availability-table tr,
	.sba-availability-table td { display: block; width: 100%; }
	.sba-availability-table tr { padding: 9px 13px; }
	.sba-availability-table td { padding: 2px 0; }
	.sba-product-action { text-align: left; }
	.sba-group-summary { padding: 10px 13px 13px; }
}

.sba-product-notice.sba-product-status-notice {
	border: 1px solid rgba(91, 74, 48, 0.18);
	background: #fff8ec;
	padding: 0.9rem 1rem;
	margin: 0 0 1rem;
	border-radius: 10px;
	font-size: 0.95rem;
	line-height: 1.5;
}

.sba-product-notice.sba-product-status-notice strong {
	display: inline;
	font-weight: 700;
}

.sba-product-notice.sba-product-status-notice a {
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.sba-product-status-notice-limited { background: #fff8ec; }
.sba-product-status-notice-coming_soon { background: #eef5ff; }
.sba-product-status-notice-market_pickup_only,
.sba-product-status-notice-by_request { background: #fff8ec; }
.sba-product-status-notice-sold_out,
.sba-product-status-notice-unavailable,
.sba-product-status-notice-not_this_year { background: #f7f4ee; }

.sba-stale-warning {
	background: #fff8ec;
	border: 1px solid rgba(91, 74, 48, 0.16);
	border-radius: 10px;
	padding: 10px 12px;
	margin: 8px 0 0;
	font-size: 0.95rem;
}

.sba-notify-inline {
	display: flex;
	gap: 6px;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: nowrap;
}

.sba-notify-inline input[type="email"] {
	width: 150px;
	max-width: 100%;
	min-height: 34px;
	border-radius: 999px;
	padding: 6px 10px;
	font-size: 0.9rem;
}

.sba-notify-inline button {
	border: 1px solid currentColor;
	border-radius: 999px;
	background: transparent;
	padding: 6px 11px;
	font-weight: 700;
	cursor: pointer;
	font-size: 0.9rem;
}

.sba-notify-success {
	margin-bottom: 14px;
}

@media (max-width: 700px) {
	.sba-notify-inline { justify-content: flex-start; }
	.sba-notify-inline input[type="email"] { width: 100%; }
}

.sba-harvest-note-title {
	font-size: 0.9rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin: 0 0 6px;
	opacity: 0.72;
}

.sba-harvest-note p:last-child {
	margin-bottom: 0;
}

.sba-notify-toggle {
	appearance: none;
	background: transparent;
	border: 0;
	color: inherit;
	font: inherit;
	font-weight: 700;
	padding: 0;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.sba-notify-toggle:hover,
.sba-notify-toggle:focus {
	opacity: 0.78;
}

.sba-notify-inline[hidden] {
	display: none !important;
}


.sba-harvest-note-kicker {
	margin: -2px 0 8px;
	font-size: 0.94rem;
	font-style: italic;
	opacity: 0.78;
}

.sba-status-pill.sba-status-unavailable {
	white-space: normal;
}
