/*
 * Boomm B2B Portal — frontend shell (Fase 11).
 * Scoped entirely under .bb2b-portal so it never touches the active
 * WordPress theme's body/table/a/button/input defaults.
 */

.bb2b-portal {
	--bb2b-color-primary: #2563eb;
	--bb2b-color-primary-hover: #1d4ed8;
	--bb2b-color-primary-soft: #eff6ff;
	--bb2b-color-success: #16a34a;
	--bb2b-color-success-soft: #ecfdf5;
	--bb2b-color-warning: #d97706;
	--bb2b-color-warning-soft: #fffbeb;
	--bb2b-color-danger: #dc2626;
	--bb2b-color-danger-soft: #fef2f2;
	--bb2b-color-text: #111827;
	--bb2b-color-text-muted: #6b7280;
	--bb2b-color-border: #e5e7eb;
	--bb2b-color-background: #f8fafc;
	--bb2b-color-surface: #ffffff;
	--bb2b-radius-md: 10px;
	--bb2b-radius-lg: 16px;
	--bb2b-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
	--bb2b-shadow-md: 0 8px 24px rgba(15, 23, 42, 0.08);
	--bb2b-font: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	font-family: var(--bb2b-font);
	color: var(--bb2b-color-text);
	background: var(--bb2b-color-background);
	padding: 24px 0;
}

.bb2b-portal__shell {
	max-width: 1010px;
	margin: 0 auto;
	padding: 0 16px;
}

.bb2b-portal__breadcrumb {
	font-size: 14px;
	color: var(--bb2b-color-text-muted);
	margin: 0 0 16px;
}

.bb2b-portal__breadcrumb a {
	color: var(--bb2b-color-primary);
	text-decoration: none;
}

.bb2b-portal__breadcrumb a:hover {
	color: var(--bb2b-color-primary-hover);
	text-decoration: underline;
}

.bb2b-portal__header {
	margin: 0 0 24px;
}

.bb2b-portal__title {
	font-size: 24px;
	font-weight: 600;
	margin: 0 0 4px;
	color: var(--bb2b-color-text);
}

.bb2b-portal__subtitle {
	font-size: 14px;
	color: var(--bb2b-color-text-muted);
	margin: 0;
}

.bb2b-portal__summary {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 16px;
	margin: 0 0 24px;
}

.bb2b-portal__summary-card {
	background: var(--bb2b-color-surface);
	border-radius: var(--bb2b-radius-lg);
	box-shadow: var(--bb2b-shadow-sm);
	padding: 16px;
}

.bb2b-portal__summary-label {
	display: block;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--bb2b-color-text-muted);
	margin: 0 0 4px;
}

.bb2b-portal__summary-value {
	font-size: 16px;
	font-weight: 600;
	color: var(--bb2b-color-text);
}

.bb2b-portal__card {
	background: var(--bb2b-color-surface);
	border-radius: var(--bb2b-radius-lg);
	box-shadow: var(--bb2b-shadow-sm);
	padding: 24px;
	margin: 0 0 24px;
}

.bb2b-portal__card-title {
	font-size: 18px;
	font-weight: 600;
	margin: 0 0 16px;
}

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

.bb2b-portal table.bb2b-portal__table th,
.bb2b-portal table.bb2b-portal__table td {
	padding: 12px 8px;
	text-align: left;
	border-bottom: 1px solid var(--bb2b-color-border);
}

.bb2b-portal table.bb2b-portal__table thead th {
	background: var(--bb2b-color-background);
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--bb2b-color-text-muted);
	border-bottom: 1px solid var(--bb2b-color-border);
}

.bb2b-portal table.bb2b-portal__table tbody tr:last-child td {
	border-bottom: none;
}

.bb2b-portal__badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	white-space: nowrap;
}

.bb2b-portal__badge::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: currentColor;
}

.bb2b-portal__badge--success {
	background: var(--bb2b-color-success-soft);
	color: var(--bb2b-color-success);
}

.bb2b-portal__badge--warning {
	background: var(--bb2b-color-warning-soft);
	color: var(--bb2b-color-warning);
}

.bb2b-portal__badge--danger {
	background: var(--bb2b-color-danger-soft);
	color: var(--bb2b-color-danger);
}

.bb2b-portal__badge--info {
	background: var(--bb2b-color-primary-soft);
	color: var(--bb2b-color-primary);
}

.bb2b-portal__badge--neutral {
	background: var(--bb2b-color-background);
	color: var(--bb2b-color-text-muted);
}

.bb2b-portal__link {
	color: var(--bb2b-color-primary);
	text-decoration: none;
	font-weight: 600;
	font-size: 14px;
}

.bb2b-portal__link:hover {
	color: var(--bb2b-color-primary-hover);
	text-decoration: underline;
}

.bb2b-portal__back-link {
	display: inline-block;
	margin: 0 0 16px;
}

.bb2b-portal__pagination {
	margin: 16px 0 0;
	font-size: 14px;
}

.bb2b-portal__pagination a,
.bb2b-portal__pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 32px;
	height: 32px;
	padding: 0 6px;
	margin-right: 4px;
	border-radius: var(--bb2b-radius-md);
	color: var(--bb2b-color-text);
	text-decoration: none;
}

.bb2b-portal__pagination a:hover {
	background: var(--bb2b-color-primary-soft);
}

.bb2b-portal__pagination span.current {
	background: var(--bb2b-color-primary);
	color: #ffffff;
}

.bb2b-portal__empty {
	text-align: center;
	padding: 40px 16px;
	color: var(--bb2b-color-text-muted);
}

.bb2b-portal__notice {
	background: var(--bb2b-color-surface);
	border-radius: var(--bb2b-radius-lg);
	box-shadow: var(--bb2b-shadow-sm);
	padding: 24px;
	text-align: center;
	color: var(--bb2b-color-text-muted);
}

.bb2b-portal__card.bb2b-portal__notice {
	text-align: left;
	padding: 16px 20px;
}

.bb2b-portal__notice--success {
	border-left: 4px solid var(--bb2b-color-success);
}

.bb2b-portal__notice--danger {
	border-left: 4px solid var(--bb2b-color-danger);
}

.bb2b-portal__form-row {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin: 0 0 16px;
	max-width: 320px;
}

.bb2b-portal__form-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--bb2b-color-text);
}

.bb2b-portal__form-input {
	font-family: var(--bb2b-font);
	font-size: 14px;
	color: var(--bb2b-color-text);
	padding: 10px 12px;
	border: 1px solid var(--bb2b-color-border);
	border-radius: var(--bb2b-radius-md);
	background: var(--bb2b-color-surface);
}

.bb2b-portal__form-input:focus {
	outline: none;
	border-color: var(--bb2b-color-primary);
}

.bb2b-portal__form-actions {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 16px 0 0;
}

.bb2b-portal__button {
	font-family: var(--bb2b-font);
	font-size: 14px;
	font-weight: 600;
	color: var(--bb2b-color-text);
	background: var(--bb2b-color-surface);
	border: 1px solid var(--bb2b-color-border);
	border-radius: var(--bb2b-radius-md);
	padding: 10px 18px;
	cursor: pointer;
}

.bb2b-portal__button--primary {
	background: var(--bb2b-color-primary);
	border-color: var(--bb2b-color-primary);
	color: #ffffff;
}

.bb2b-portal__button--primary:hover {
	background: var(--bb2b-color-primary-hover);
	border-color: var(--bb2b-color-primary-hover);
}

.bb2b-portal__button--disabled,
.bb2b-portal__button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.bb2b-portal__link--button {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	font-family: var(--bb2b-font);
}

/*
 * Portal Shell (Fase 12.1.2) — sidebar + topbar app chrome wrapping the
 * front-end Portal B2B screens. Scoped entirely under .bb2b-app, a sibling
 * wrapper to .bb2b-portal (never the other way around), so it never reaches
 * outside its own markup into the active WordPress theme.
 */

.bb2b-app {
	--bb2b-color-primary: #2563eb;
	--bb2b-color-primary-hover: #1d4ed8;
	--bb2b-color-primary-soft: #eff6ff;
	--bb2b-color-text: #111827;
	--bb2b-color-text-muted: #6b7280;
	--bb2b-color-border: #e5e7eb;
	--bb2b-color-background: #f8fafc;
	--bb2b-color-surface: #ffffff;
	--bb2b-color-sidebar: #111827;
	--bb2b-color-sidebar-active: #2563eb;
	--bb2b-font: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	display: flex;
	min-height: 480px;
	font-family: var(--bb2b-font);
	color: var(--bb2b-color-text);
	background: var(--bb2b-color-background);
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.bb2b-app__sidebar {
	flex: 0 0 220px;
	background: var(--bb2b-color-sidebar);
	color: #f9fafb;
	padding: 24px 16px;
}

.bb2b-app__logo {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 24px;
	padding: 0 8px;
}

.bb2b-app__logo-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 8px;
	background: var(--bb2b-color-primary);
	color: #ffffff;
	font-weight: 700;
}

.bb2b-app__logo-text {
	font-weight: 600;
	line-height: 1.2;
}

.bb2b-app__logo-sub {
	display: block;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.04em;
	color: #9ca3af;
}

.bb2b-app__nav {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.bb2b-app__nav-link {
	display: block;
	padding: 10px 12px;
	border-radius: 10px;
	color: #d1d5db;
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
}

.bb2b-app__nav-link:hover {
	background: rgba(255, 255, 255, 0.06);
	color: #f9fafb;
}

.bb2b-app__nav-link--active {
	background: var(--bb2b-color-sidebar-active);
	color: #ffffff;
}

.bb2b-app__body {
	flex: 1 1 auto;
	min-width: 0;
	background: var(--bb2b-color-background);
}

.bb2b-app__topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 24px;
	background: var(--bb2b-color-surface);
	border-bottom: 1px solid var(--bb2b-color-border);
}

.bb2b-app__topbar-company strong {
	font-size: 14px;
	color: var(--bb2b-color-text);
}

.bb2b-app__topbar-actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

.bb2b-app__draft-pill,
.bb2b-app__user-pill {
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--bb2b-color-primary-soft);
	color: var(--bb2b-color-primary);
	font-size: 13px;
	font-weight: 600;
}

.bb2b-app__user-pill {
	background: var(--bb2b-color-background);
	color: var(--bb2b-color-text);
}

.bb2b-app__main {
	padding: 8px 0;
}

/* The legacy Fase 11 page-level wrapper, when nested inside the new shell,
 * should not repeat the page background/padding - the shell already
 * provides it. */
.bb2b-app .bb2b-portal {
	padding: 16px 0;
	background: transparent;
}

.bb2b-portal__form--inline {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 16px;
}

.bb2b-portal__form-row--narrow {
	max-width: 140px;
}

@media (max-width: 720px) {
	.bb2b-app {
		flex-direction: column;
	}

	.bb2b-app__sidebar {
		flex: none;
	}

	.bb2b-app__nav {
		flex-direction: row;
		flex-wrap: wrap;
	}

	.bb2b-app__topbar {
		flex-wrap: wrap;
	}
}
