.page.home {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
	padding-bottom: 3rem;
}

/* Dashboard Home Styles */
.dashboard-home {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.dashboard-loader {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 4rem 2rem;
	color: var(--color-text-muted);
}

.loader-spinner {
	width: 40px;
	height: 40px;
	border: 3px solid rgba(37, 99, 235, 0.2);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

.dashboard-welcome {
	background: linear-gradient(135deg, var(--color-primary) 0%, #1e40af 100%);
	border-radius: var(--radius-lg);
	padding: clamp(1.5rem, 4vw, 2.5rem);
	color: #ffffff;
}

.dashboard-welcome h1 {
	margin: 0 0 0.5rem;
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: #ffffff;
}

.dashboard-welcome .welcome-name {
	color: #fbbf24;
}

.dashboard-welcome .welcome-subtitle {
	margin: 0;
	opacity: 0.9;
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.9);
}

/* Stats Section */
.stats-section {
	margin-top: -1rem;
}

.stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 1rem;
}

.stat-card {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	padding: 1.25rem;
	display: flex;
	align-items: center;
	gap: 1rem;
	transition: box-shadow 0.2s, transform 0.2s;
}

.stat-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.stat-icon {
	width: 48px;
	height: 48px;
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
}

.stat-primary .stat-icon { background: rgba(37, 99, 235, 0.12); color: var(--color-primary); }
.stat-secondary .stat-icon { background: rgba(124, 58, 237, 0.12); color: #7c3aed; }
.stat-success .stat-icon { background: rgba(16, 185, 129, 0.12); color: #10b981; }
.stat-warning .stat-icon { background: rgba(251, 191, 36, 0.12); color: #f59e0b; }
.stat-muted .stat-icon { background: rgba(100, 116, 139, 0.12); color: #64748b; }

.stat-content {
	display: flex;
	flex-direction: column;
}

.stat-value {
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-text-main);
}

.stat-label {
	font-size: 0.85rem;
	color: var(--color-text-muted);
}

/* Quick Actions */
.quick-actions {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.section-title {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--color-text-main);
}

.section-title i {
	color: var(--color-primary);
}

.quick-actions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1rem;
}

.quick-action-card {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.25rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all 0.2s;
	text-align: left;
}

.quick-action-card:hover {
	border-color: var(--color-primary);
	box-shadow: 0 4px 12px rgba(37, 99, 235, 0.15);
	transform: translateY(-2px);
}

.quick-action-icon {
	width: 48px;
	height: 48px;
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	flex-shrink: 0;
}

.quick-action-primary .quick-action-icon {
	background: var(--color-primary);
	color: #ffffff;
}

.quick-action-secondary .quick-action-icon {
	background: #7c3aed;
	color: #ffffff;
}

.quick-action-content {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.quick-action-label {
	font-weight: 600;
	color: var(--color-text-main);
}

.quick-action-desc {
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

.quick-action-arrow {
	color: var(--color-text-muted);
	transition: transform 0.2s;
}

.quick-action-card:hover .quick-action-arrow {
	transform: translateX(4px);
	color: var(--color-primary);
}

/* Recent Items */
.recent-section {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.recent-columns {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 1.5rem;
}

.recent-column {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.recent-column-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.recent-column-header h3 {
	margin: 0;
	font-size: 1rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.view-all-link {
	font-size: 0.875rem;
	color: var(--color-primary);
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.view-all-link:hover {
	text-decoration: underline;
}

.items-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.item-card {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all 0.2s;
}

.item-card:hover {
	border-color: var(--color-primary);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.item-card-icon {
	width: 40px;
	height: 40px;
	border-radius: var(--radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.item-card-icon.survey-icon {
	background: rgba(37, 99, 235, 0.12);
	color: var(--color-primary);
}

.item-card-icon.doodle-icon {
	background: rgba(124, 58, 237, 0.12);
	color: #7c3aed;
}

.item-card-content {
	flex: 1;
	min-width: 0;
}

.item-card-title {
	margin: 0 0 0.35rem;
	font-size: 0.95rem;
	font-weight: 600;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.item-card-meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 0.8rem;
}

.item-status {
	padding: 0.2rem 0.5rem;
	border-radius: 4px;
	font-weight: 500;
	text-transform: uppercase;
	font-size: 0.7rem;
	letter-spacing: 0.03em;
}

.item-status.status-draft { background: rgba(100, 116, 139, 0.15); color: #64748b; }
.item-status.status-published { background: rgba(16, 185, 129, 0.15); color: #059669; }
.item-status.status-closed { background: rgba(239, 68, 68, 0.15); color: #dc2626; }
.item-status.status-archived { background: rgba(107, 114, 128, 0.15); color: #6b7280; }

.item-responses {
	color: var(--color-text-muted);
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.item-card-actions {
	color: var(--color-text-muted);
}

/* Empty State */
.empty-state-card {
	background: #ffffff;
	border: 2px dashed rgba(15, 23, 42, 0.12);
	border-radius: var(--radius-lg);
	padding: 3rem 2rem;
	text-align: center;
}

.empty-state-icon {
	width: 64px;
	height: 64px;
	margin: 0 auto 1rem;
	background: rgba(37, 99, 235, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	color: var(--color-primary);
}

.empty-state-card h3 {
	margin: 0 0 0.5rem;
	font-size: 1.1rem;
}

.empty-state-card p {
	margin: 0 0 1.5rem;
	color: var(--color-text-muted);
}

.empty-state-actions {
	display: flex;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
}

/* Admin Panel */
.admin-panel-section {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	padding: 1.25rem;
}

.admin-panel-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1rem;
}

.admin-panel-header h3 {
	margin: 0;
	font-size: 1rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.admin-badge {
	background: rgba(239, 68, 68, 0.15);
	color: #dc2626;
	padding: 0.25rem 0.6rem;
	border-radius: 4px;
	font-size: 0.75rem;
	font-weight: 600;
}

.admin-links {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 0.75rem;
}

.admin-link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem;
	background: rgba(15, 23, 42, 0.03);
	border-radius: var(--radius-sm);
	color: var(--color-text-main);
	text-decoration: none;
	font-size: 0.9rem;
	transition: all 0.2s;
}

.admin-link:hover {
	background: var(--color-primary);
	color: #ffffff;
}

.admin-link-warning {
	background: rgba(251, 191, 36, 0.15);
}

.admin-link-warning:hover {
	background: #f59e0b;
}

/* Dashboard Error */
.dashboard-error {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 4rem 2rem;
	text-align: center;
	color: var(--color-text-muted);
}

.dashboard-error i {
	font-size: 2.5rem;
	color: #f59e0b;
}

/* ========================================
   Tracking Page (Mes suivis)
   ======================================== */

.page.tracking {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
	padding-bottom: 3rem;
}

.tracking-content {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.tracking-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
}

.tracking-header h1 {
	margin: 0;
	font-size: 1.75rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--color-text-main);
}

.tracking-header h1 i {
	color: var(--color-primary);
}

.tracking-subtitle {
	margin: 0.25rem 0 0;
	color: var(--color-text-muted);
}

.tracking-loader {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 4rem 2rem;
	color: var(--color-text-muted);
}

.tracking-stats {
	margin-bottom: 0.5rem;
}

.tracking-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	padding: 1rem 1.25rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
}

.filter-group {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.filter-group label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text-muted);
}

.filter-buttons {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.filter-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.5rem 0.85rem;
	font-size: 0.85rem;
	font-weight: 500;
	background: rgba(15, 23, 42, 0.04);
	border: 1px solid transparent;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: all 0.2s;
	color: var(--color-text-muted);
}

.filter-btn:hover {
	background: rgba(15, 23, 42, 0.08);
	color: var(--color-text-main);
}

.filter-btn.active {
	background: var(--color-primary);
	color: #ffffff;
	border-color: var(--color-primary);
}

.filter-btn i {
	font-size: 0.8rem;
}

.tracking-table-wrapper {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.tracking-table {
	width: 100%;
	border-collapse: collapse;
}

.tracking-table thead {
	background: rgba(15, 23, 42, 0.03);
}

.tracking-table th {
	padding: 0.85rem 1rem;
	font-size: 0.8rem;
	font-weight: 600;
	text-align: left;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--color-text-muted);
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.tracking-row {
	cursor: pointer;
	transition: background 0.15s;
}

.tracking-row:hover {
	background: rgba(37, 99, 235, 0.04);
}

.tracking-row.loading {
	opacity: 0.5;
	pointer-events: none;
}

.tracking-row td {
	padding: 0.85rem 1rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
	vertical-align: middle;
}

.tracking-row:last-child td {
	border-bottom: none;
}

.tracking-cell-icon {
	width: 50px;
}

.item-type-icon {
	width: 36px;
	height: 36px;
	border-radius: var(--radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
}

.item-type-icon.survey-icon {
	background: rgba(37, 99, 235, 0.12);
	color: var(--color-primary);
}

.item-type-icon.doodle-icon {
	background: rgba(124, 58, 237, 0.12);
	color: #7c3aed;
}

.tracking-cell-title {
	min-width: 200px;
}

.tracking-cell-title .item-title {
	display: block;
	font-weight: 600;
	color: var(--color-text-main);
	margin-bottom: 0.2rem;
}

.tracking-cell-title .item-owner {
	display: block;
	font-size: 0.8rem;
	color: var(--color-text-muted);
}

.tracking-cell-status {
	width: 100px;
}

.tracking-cell-role {
	width: 130px;
}

.item-role {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.3rem 0.6rem;
	font-size: 0.75rem;
	font-weight: 600;
	border-radius: 4px;
}

.item-role.role-owner {
	background: rgba(251, 191, 36, 0.15);
	color: #b45309;
}

.item-role.role-manager {
	background: rgba(16, 185, 129, 0.15);
	color: #059669;
}

.item-role.role-analyst {
	background: rgba(99, 102, 241, 0.15);
	color: #4f46e5;
}

.tracking-cell-responses {
	width: 100px;
	color: var(--color-text-muted);
	font-size: 0.9rem;
}

.tracking-cell-responses i {
	margin-right: 0.35rem;
	opacity: 0.7;
}

.tracking-cell-date {
	width: 120px;
	font-size: 0.85rem;
	color: var(--color-text-muted);
}

.tracking-cell-actions {
	width: 50px;
	text-align: right;
}

.tracking-cell-actions .btn-icon {
	width: 32px;
	height: 32px;
	border-radius: var(--radius-sm);
	border: none;
	background: transparent;
	cursor: pointer;
	color: var(--color-text-muted);
	transition: all 0.2s;
}

.tracking-cell-actions .btn-icon:hover {
	background: var(--color-primary);
	color: #ffffff;
}

.tracking-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 4rem 2rem;
	text-align: center;
	background: #ffffff;
	border: 2px dashed rgba(15, 23, 42, 0.12);
	border-radius: var(--radius-lg);
}

.tracking-empty .empty-state-icon {
	width: 64px;
	height: 64px;
	background: rgba(37, 99, 235, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	color: var(--color-primary);
}

.tracking-empty h3 {
	margin: 0;
	font-size: 1.1rem;
	color: var(--color-text-main);
}

.tracking-empty p {
	margin: 0;
	color: var(--color-text-muted);
}

.tracking-empty .empty-state-actions {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 0.5rem;
}

.tracking-error {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 4rem 2rem;
	text-align: center;
	color: var(--color-text-muted);
}

.tracking-error i {
	font-size: 2.5rem;
	color: #f59e0b;
}

/* Responsive table */
@media (max-width: 768px) {
	.tracking-filters {
		flex-direction: column;
		gap: 1rem;
	}
	
	.filter-group {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.5rem;
	}
	
	.tracking-table-wrapper {
		overflow-x: auto;
	}
	
	.tracking-table {
		min-width: 700px;
	}
}

.page.setup {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.setup-content {
	max-width: 640px;
	margin: 0 auto;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.setup-header {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
}

.setup-header h1 {
	margin: 0;
}

.setup-header p {
	margin: 0;
	color: var(--color-text-muted);
}

.setup-logo {
	width: 72px;
	height: 72px;
	background: linear-gradient(135deg, var(--color-primary), #1e40af);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	color: #fff;
	margin-bottom: 0.5rem;
	box-shadow: 0 8px 24px -8px rgba(37, 99, 235, 0.4);
}

.setup-loading {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 3rem;
	color: var(--color-text-muted);
}

/* Setup Steps Indicator */
.setup-steps {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0;
	margin: 0.5rem 0 1rem;
}

.setup-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
}

.step-icon {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	background: var(--color-bg-muted);
	color: var(--color-text-muted);
	border: 2px solid var(--color-border);
	transition: all 0.2s;
}

.setup-step.current .step-icon {
	background: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
	box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}

.setup-step.completed .step-icon {
	background: var(--color-success);
	color: #fff;
	border-color: var(--color-success);
}

.step-label {
	font-size: 0.8rem;
	font-weight: 500;
	color: var(--color-text-muted);
}

.setup-step.current .step-label {
	color: var(--color-primary);
}

.setup-step.completed .step-label {
	color: var(--color-success);
}

.step-connector {
	width: 48px;
	height: 2px;
	background: var(--color-border);
	margin: 0 0.5rem;
	margin-bottom: 1.5rem;
}

/* Setup Config Form */
.setup-config-card {
	padding: clamp(1.25rem, 4vw, 1.75rem);
}

.setup-config-card .card-header {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--color-border);
}

.setup-config-card .card-icon {
	width: 52px;
	height: 52px;
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
	background: rgba(37, 99, 235, 0.1);
	color: var(--color-primary);
}

.setup-config-card .card-title h2 {
	margin: 0;
	font-size: 1.15rem;
}

.setup-config-card .card-title p {
	margin: 0.25rem 0 0;
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.setup-form fieldset {
	border: none;
	padding: 0;
	margin: 0 0 1.5rem;
}

.setup-form fieldset:last-of-type {
	margin-bottom: 0.5rem;
}

.setup-form legend {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--color-text-secondary);
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1rem;
	padding: 0;
}

.setup-form legend i {
	color: var(--color-primary);
}

.form-grid {
	display: grid;
	gap: 1rem;
}

.form-field {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.form-field label {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--color-text-secondary);
}

.form-field label .required {
	color: var(--color-danger);
	margin-left: 0.15rem;
}

.input-with-action {
	display: flex;
	gap: 0.5rem;
	align-items: stretch;
}

.input-with-action input {
	flex: 1;
}

.input-with-action .btn {
	padding: 0.5rem 0.75rem;
}

.field-status {
	font-size: 0.75rem;
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.field-status.configured {
	color: var(--color-success);
}

.form-hint {
	margin: 0.75rem 0 0;
	padding: 0.75rem;
	background: rgba(37, 99, 235, 0.06);
	border-radius: var(--radius-sm);
	font-size: 0.85rem;
	color: var(--color-text-muted);
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}

.form-hint i {
	color: #f59e0b;
	flex-shrink: 0;
	margin-top: 0.15rem;
}

.form-feedback {
	min-height: 1.25rem;
	font-size: 0.85rem;
	margin: 0.5rem 0;
}

.form-feedback.error {
	color: var(--color-danger);
}

.form-feedback.success {
	color: var(--color-success);
}

/* Setup Done */
.setup-done-card {
	padding: clamp(2rem, 5vw, 3rem);
	text-align: center;
}

.setup-done-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto 1.5rem;
	border-radius: 50%;
	background: rgba(16, 185, 129, 0.12);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.5rem;
	color: var(--color-success);
}

.setup-done-card h2 {
	margin: 0 0 0.5rem;
	font-size: 1.5rem;
}

.setup-done-card p {
	margin: 0 0 1.5rem;
	color: var(--color-text-muted);
}

.setup-done-card .form-actions {
	justify-content: center;
}

.page.doodle-builder {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.page.admin-segments {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.page.admin-entities {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.page.admin-roles {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.page.forbidden {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
}

.page.invite-access {
	display: flex;
	flex-direction: column;
	gap: clamp(1.25rem, 3vw, 2rem);
}

.invite-header {
	max-width: 720px;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.invite-eyebrow {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.85rem;
	color: var(--color-text-muted);
}

.invite-header h1 {
	margin: 0;
}

.invite-header p {
	margin: 0;
	color: var(--color-text-muted);
}

.invite-layout {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: minmax(0, 1fr);
	justify-items: center;
}

.invite-card {
	background: #ffffff;
	border-radius: var(--radius-lg);
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 22px 45px -30px rgba(15, 23, 42, 0.35);
	padding: clamp(1.25rem, 3vw, 1.75rem);
	max-width: 720px;
	width: 100%;
}

.invite-card-head {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0.75rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
	padding-bottom: 0.75rem;
	margin-bottom: 1rem;
}

.invite-stepper {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	font-weight: 600;
}

.invite-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	background: rgba(37, 99, 235, 0.12);
	color: var(--color-primary);
	font-weight: 700;
	transition: all 160ms ease;
}

.invite-pill.is-active {
	background: var(--color-primary);
	color: #ffffff;
	box-shadow: 0 10px 30px -12px rgba(37, 99, 235, 0.65);
}

.invite-form {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.invite-step {
	border: 1px solid rgba(15, 23, 42, 0.06);
	border-radius: var(--radius-md);
	padding: 1rem;
	background: linear-gradient(180deg, rgba(248, 250, 252, 0.85), #ffffff 48%);
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transform: translateY(6px);
	transition: all 220ms ease;
	pointer-events: none;
}

.invite-step.is-active {
	max-height: 520px;
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.invite-hints {
	margin: 0.5rem 0 0;
	padding-left: 1.1rem;
	color: var(--color-text-muted);
	line-height: 1.5;
	font-size: 0.95rem;
}

.invite-hints li + li {
	margin-top: 0.25rem;
}

.invite-summary {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.invite-summary strong {
	font-size: 1rem;
	font-weight: 700;
}

.invite-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.invite-feedback {
	margin: 0;
	padding: 0.75rem 0.85rem;
	border-radius: var(--radius-sm);
	border: 1px solid rgba(15, 23, 42, 0.08);
	background: rgba(15, 23, 42, 0.02);
	color: var(--color-text-muted);
}

.invite-feedback[data-variant="error"] {
	background: rgba(220, 38, 38, 0.08);
	color: #991b1b;
	border-color: rgba(220, 38, 38, 0.15);
}

.invite-feedback[data-variant="success"] {
	background: rgba(22, 163, 74, 0.08);
	color: #166534;
	border-color: rgba(22, 163, 74, 0.18);
}

.forbidden-shell {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: clamp(2rem, 6vw, 3.5rem);
}

.forbidden-card {
	max-width: 420px;
	width: 100%;
	background: #ffffff;
	border-radius: var(--radius-md);
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 22px 45px -30px rgba(15, 23, 42, 0.35);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1.25rem;
	padding: clamp(2rem, 5vw, 3rem);
}

.forbidden-icon {
	width: 3.5rem;
	height: 3.5rem;
	display: grid;
	place-items: center;
	border-radius: 999px;
	background: rgba(37, 99, 235, 0.12);
	color: var(--color-primary);
	font-size: 1.5rem;
}

.forbidden-card h2 {
	margin: 0;
}

.forbidden-card p {
	margin: 0;
	color: var(--color-text-muted);
	line-height: 1.6;
}

.forbidden-actions {
	display: flex;
	justify-content: center;
}

/* ============================================
   ADMIN ROLES PAGE
   ============================================ */

.admin-roles-layout {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

.admin-roles-header {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

.admin-roles-header h2 {
	margin: 0 0 0.35rem;
}

.admin-roles-header p {
	margin: 0;
	color: var(--color-text-muted);
}

.admin-roles-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.admin-roles-error {
	padding: 1rem 1.2rem;
	border-radius: var(--radius-sm);
	background: rgba(185, 28, 28, 0.12);
	color: var(--color-danger);
	border: 1px solid rgba(185, 28, 28, 0.18);
	font-size: 0.9rem;
}

.admin-roles-list {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

.admin-roles-list-empty {
	min-height: 220px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.9rem;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.admin-roles-list-empty i {
	font-size: 1.8rem;
	color: rgba(37, 99, 235, 0.45);
}

.admin-roles-list-empty .loading-spinner {
	width: 2.25rem;
	height: 2.25rem;
}

.admin-roles-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.9rem;
}

@media (min-width: 920px) {
	.admin-roles-grid {
		grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
	}
}

/* Role Card */
.admin-role-card {
	background: #ffffff;
	border-radius: var(--radius-md);
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 24px 48px -32px rgba(15, 23, 42, 0.25);
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	padding: 1.15rem 1.25rem;
	transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.admin-role-card:hover {
	border-color: rgba(37, 99, 235, 0.2);
	box-shadow: 0 24px 48px -28px rgba(37, 99, 235, 0.18);
}

.admin-role-card-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.admin-role-card-header h3 {
	margin: 0;
	font-size: 1.05rem;
	color: var(--color-text-main);
}

.admin-role-card-code {
	margin: 0.2rem 0 0;
	font-family: 'Consolas', 'Fira Code', 'SFMono-Regular', monospace;
	font-size: 0.8rem;
	color: var(--color-text-muted);
	background: rgba(15, 23, 42, 0.05);
	padding: 0.15rem 0.45rem;
	border-radius: var(--radius-sm);
	display: inline-block;
}

.admin-role-card-description {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.9rem;
	line-height: 1.5;
}

.admin-role-card-description--empty {
	font-style: italic;
	opacity: 0.7;
}

/* Role Card Permissions Section */
.admin-role-card-permissions {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding-top: 0.65rem;
	border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.admin-role-card-permissions h4 {
	margin: 0 0 0.35rem;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-text-muted);
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 0.4rem;
}

.admin-role-card-permissions h4 i {
	font-size: 0.85rem;
	color: rgba(37, 99, 235, 0.6);
}

.admin-role-permissions {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
}

.admin-role-permission-chip {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.25rem 0.55rem;
	border-radius: var(--radius-full);
	background: rgba(37, 99, 235, 0.08);
	border: 1px solid rgba(37, 99, 235, 0.18);
	font-size: 0.78rem;
	color: var(--color-primary);
}

.admin-role-permission-chip-label {
	font-weight: 500;
}

.admin-role-permission-chip-meta {
	display: none;
}

.admin-role-permission-chip-description {
	display: none;
}

.admin-role-permission-chip-badge {
	display: none;
}

.admin-role-permission-chip-code {
	display: none;
}

.admin-role-permissions-empty {
	color: var(--color-text-muted);
	font-style: italic;
	font-size: 0.85rem;
}

/* Role Card Actions */
.admin-role-card-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	align-items: center;
	padding-top: 0.5rem;
}

/* ============================================
   ROLE EDITOR MODAL
   ============================================ */

.admin-roles-editor {
	position: fixed;
	inset: 0;
	z-index: 1300;
	display: none;
}

.admin-roles-editor[data-open='true'] {
	display: block;
}

.admin-roles-editor-modal {
	max-height: min(92vh, 100%);
	display: flex;
	flex-direction: column;
	width: min(600px, 100%);
}

.admin-roles-editor-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

.admin-roles-editor-header h2 {
	margin: 0;
}

.admin-roles-editor-form {
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	padding: 1.5rem 1.75rem 1.75rem;
}

.admin-roles-editor-permissions {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	padding: 1rem;
	background: rgba(15, 23, 42, 0.02);
	border-radius: var(--radius-md);
	border: 1px solid rgba(15, 23, 42, 0.06);
}

.admin-roles-editor-permissions header {
	padding-bottom: 0.65rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.admin-roles-editor-permissions header h3 {
	margin: 0 0 0.25rem;
	font-size: 1rem;
}

.admin-roles-editor-permissions header p {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.88rem;
}

/* Permission Groups in Editor */
.admin-roles-permission-group {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.admin-roles-permission-group + .admin-roles-permission-group {
	margin-top: 0.85rem;
	padding-top: 0.85rem;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.admin-roles-permission-group header {
	padding-bottom: 0;
	border-bottom: none;
}

.admin-roles-permission-group header h4 {
	margin: 0;
	font-size: 0.82rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-text-muted);
	font-weight: 600;
}

.admin-roles-permission-options {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.admin-roles-permission-option {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.65rem;
	align-items: flex-start;
	padding: 0.6rem 0.75rem;
	background: #ffffff;
	border-radius: var(--radius-sm);
	border: 1px solid rgba(15, 23, 42, 0.08);
	cursor: pointer;
	transition: background 0.12s ease, border-color 0.12s ease;
}

.admin-roles-permission-option:hover {
	background: rgba(37, 99, 235, 0.03);
	border-color: rgba(37, 99, 235, 0.15);
}

.admin-roles-permission-option input[type="checkbox"] {
	margin-top: 0.2rem;
	width: 1rem;
	height: 1rem;
	accent-color: var(--color-primary);
}

.admin-roles-permission-option-main {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.admin-roles-permission-option-main strong {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-text-main);
}

.admin-roles-permission-option-code {
	font-family: 'Consolas', 'Fira Code', 'SFMono-Regular', monospace;
	font-size: 0.75rem;
	color: var(--color-text-muted);
	background: rgba(15, 23, 42, 0.05);
	padding: 0.1rem 0.35rem;
	border-radius: var(--radius-sm);
	display: inline-block;
	width: fit-content;
}

.admin-roles-permission-option-main small {
	color: var(--color-text-muted);
	font-size: 0.82rem;
	line-height: 1.4;
}

.admin-roles-permission-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.65rem;
	padding: 1.5rem;
	color: var(--color-text-muted);
	text-align: center;
}

.admin-roles-permission-empty i {
	font-size: 1.5rem;
	color: rgba(37, 99, 235, 0.4);
}

/* Editor Actions & Feedback */
.admin-roles-editor-feedback {
	padding: 0.85rem 1rem;
	border-radius: var(--radius-sm);
	background: rgba(220, 38, 38, 0.1);
	border: 1px solid rgba(220, 38, 38, 0.25);
	color: #991b1b;
	font-size: 0.9rem;
}

.admin-roles-editor-actions {
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
}

[data-editor-permission-list][data-disabled='true'] {
	opacity: 0.5;
	pointer-events: none;
}

/* ============================================
   END ADMIN ROLES
   ============================================ */

.dashboard-side {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.builder-layout {
	display: grid;
	gap: clamp(1.75rem, 3vw, 2.5rem);
}

.segment-admin-layout {
	display: grid;
	gap: clamp(1.75rem, 3vw, 2.5rem);
	align-items: start;
}

@media (min-width: 1080px) {
	.builder-layout {
		grid-template-columns: minmax(0, 3fr) minmax(0, 1.1fr);
	}
}

@media (min-width: 1080px) {
	.segment-admin-layout {
		grid-template-columns: minmax(240px, 1fr) minmax(0, 3fr);
	}
}

.builder-main {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

.builder-header {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.builder-side {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.page.manage {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

.manage-layout {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

.manage-content {
	display: grid;
	gap: clamp(1.5rem, 3vw, 2.25rem);
	align-items: start;
}

@media (min-width: 1024px) {
	.manage-content {
		grid-template-columns: minmax(240px, 1fr) minmax(0, 3fr);
	}
}

.manage-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.manage-panel {
	display: flex;
	flex-direction: column;
	gap: 1.15rem;
}

.manage-panel-header {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.manage-panel-header h3 {
	margin: 0;
}

.manage-panel-header p {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.9rem;
}

.manage-filter-group {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.manage-filter-group span {
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-text-muted);
}

.manage-filter-options {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.manage-filter-btn.active {
	background: rgba(37, 99, 235, 0.12);
	color: var(--color-primary);
	box-shadow: none;
}

.manage-collection {
	display: flex;
	flex-direction: column;
	padding: 0;
}

.manage-collection-header {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.5rem;
	border-bottom: 1px solid var(--color-border);
}

.manage-collection-header h3 {
	margin: 0;
}

.manage-collection-meta {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.9rem;
}

.manage-collection-body {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.manage-collection-empty {
	min-height: 220px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 0.85rem;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.manage-collection-empty i {
	font-size: 1.8rem;
	color: rgba(37, 99, 235, 0.45);
}

.manage-collection-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin: 0;
	padding: 0;
}

.manage-card {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1.35rem 1.5rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	box-shadow: 0 18px 36px -28px rgba(15, 23, 42, 0.28);
}

.manage-card-header {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0.85rem;
}

.manage-card-header h3 {
	margin: 0;
	font-size: 1.1rem;
	color: var(--color-text-main);
}

.manage-card-header p {
	margin: 0;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.manage-card-owner {
	color: var(--color-text-muted);
	gap: 0.65rem;
}

.manage-owner-action {
	appearance: none;
	border: 1px solid rgba(37, 99, 235, 0.25);
	background: rgba(37, 99, 235, 0.08);
	color: var(--color-primary);
	border-radius: 999px;
	padding: 0.25rem 0.6rem;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.85rem;
	font-weight: 600;
	cursor: pointer;
	transition: background var(--transition-base), border-color var(--transition-base), color var(--transition-base), transform var(--transition-base);
}

.manage-owner-action:hover {
	background: rgba(37, 99, 235, 0.12);
	border-color: rgba(37, 99, 235, 0.4);
	color: var(--color-primary-strong);
	transform: translateY(-1px);
}

.manage-owner-action:active {
	transform: translateY(0);
	background: rgba(37, 99, 235, 0.16);
}

.owner-transfer-body {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

.owner-transfer-label {
	font-weight: 600;
	color: var(--color-text-main);
}

.owner-transfer-search {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: var(--radius-sm);
	padding: 0.65rem 0.9rem;
	background: #ffffff;
	box-shadow: var(--shadow-soft);
}

.owner-transfer-search input {
	flex: 1;
	border: none;
	outline: none;
	font-size: 0.98rem;
}

.owner-transfer-feedback {
	margin: 0;
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.owner-transfer-feedback[data-tone='error'] {
	color: #b91c1c;
}

.owner-transfer-feedback[data-tone='info'] {
	color: #2563eb;
}

.owner-transfer-results {
	list-style: none;
	margin: 0;
	padding: 0.2rem;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-sm);
	max-height: 320px;
	overflow-y: auto;
	background: #ffffff;
}

.owner-transfer-results li + li {
	border-top: 1px solid rgba(148, 163, 184, 0.16);
}

.owner-transfer-result {
	width: 100%;
	text-align: left;
	background: transparent;
	border: none;
	padding: 0.75rem 0.9rem;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	cursor: pointer;
}

.owner-transfer-result:hover,
.owner-transfer-result:focus-visible,
.owner-transfer-result[data-selected='true'] {
	background: rgba(37, 99, 235, 0.08);
	outline: none;
}

.owner-transfer-result-name {
	font-weight: 600;
	color: var(--color-text-main);
}

.owner-transfer-result-email {
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.owner-transfer-empty {
	margin: 0;
	padding: 0.85rem 1rem;
	color: var(--color-text-muted);
}


.manage-card-footer {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.manage-card-footer span {
	background: rgba(148, 163, 184, 0.1);
	padding: 0.35rem 0.65rem;
	border-radius: var(--radius-sm);
}

.manage-card-actions {
	display: flex;
	gap: 0.6rem;
}

.manage-card-actions .btn {
	min-width: 7.5rem;
}

@media (max-width: 720px) {
	.manage-collection-header {
		flex-direction: column;
		align-items: stretch;
	}

	.manage-card-footer {
		flex-direction: column;
		align-items: flex-start;
	}
}

[data-view='login'] {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(1.5rem, 6vw, 3.5rem);
}

.page.login-page {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.login-card {
	width: min(100%, 420px);
	background: #ffffff;
	border-radius: var(--radius-md);
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 32px 48px -24px rgba(15, 23, 42, 0.18);
	padding: clamp(2rem, 4vw, 2.75rem);
	display: flex;
	flex-direction: column;
	gap: 1.75rem;
}

.login-card-header {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.login-brand {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.login-brand .brand-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 0.9rem;
	background: rgba(37, 99, 235, 0.12);
	color: var(--color-primary);
	font-weight: 700;
	font-size: 1.35rem;
}

.login-brand h1 {
	margin: 0;
	font-size: 1.5rem;
}

.login-brand p {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.login-intro {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
	line-height: 1.5;
}

.login-form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.login-form[data-loading='true'] {
	opacity: 0.85;
}

.login-feedback {
	padding: 0.85rem 1rem;
	border-radius: var(--radius-sm);
	font-size: 0.9rem;
	background: rgba(185, 28, 28, 0.12);
	color: var(--color-danger);
	border: 1px solid rgba(185, 28, 28, 0.2);
}

.login-feedback[data-variant='success'] {
	background: rgba(22, 163, 74, 0.12);
	color: var(--color-success);
	border-color: rgba(22, 163, 74, 0.2);
}

.login-footer {
	display: none;
}

.page.admin-users {
	display: flex;
	flex-direction: column;
	gap: clamp(1.75rem, 3vw, 2.75rem);
}

.admin-users-layout {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

.admin-users-header {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

.admin-users-header h2 {
	margin: 0 0 0.35rem;
}

.admin-users-header p {
	margin: 0;
	color: var(--color-text-muted);
}

.admin-users-controls {
	display: grid;
	gap: clamp(1rem, 2vw, 1.5rem);
}

@media (min-width: 880px) {
	.admin-users-controls {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		align-items: center;
	}

	.admin-users-controls > *:not(:first-child) {
		justify-self: end;
	}
}

.admin-users-search {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
}

.admin-users-search-input {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 0.9rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.14);
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-soft);
}

.admin-users-search-input i {
	color: rgba(37, 99, 235, 0.85);
}

.admin-users-search-input input {
	border: none;
	outline: none;
	font-size: 0.95rem;
}

.admin-users-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.admin-users-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
	justify-content: flex-start;
	color: var(--color-text-muted);
	font-size: 0.9rem;
}

.admin-users-error {
	padding: 1rem 1.2rem;
	border-radius: var(--radius-sm);
	background: rgba(185, 28, 28, 0.12);
	color: var(--color-danger);
	border: 1px solid rgba(185, 28, 28, 0.18);
	font-size: 0.9rem;
}

.admin-users-list {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

.admin-users-list-empty {
	min-height: 220px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.9rem;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.admin-users-list-empty i {
	font-size: 1.8rem;
	color: rgba(37, 99, 235, 0.45);
}

.admin-users-list-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.9rem;
}

.admin-users-toolbar {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 0.6rem 1rem;
	margin-bottom: 0.25rem;
}

.admin-users-view-switch {
	display: inline-flex;
	gap: 0.35rem;
}

.admin-users-view-switch .btn-ghost {
	padding: 0.45rem 0.65rem;
	border-radius: var(--radius-sm);
	border: 1px solid transparent;
	gap: 0.35rem;
}

.admin-users-view-switch .btn-ghost.is-active {
	background: rgba(37, 99, 235, 0.08);
	border-color: rgba(37, 99, 235, 0.2);
}

.admin-users-pagination {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	flex-wrap: wrap;
}

.admin-users-page-size label {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.85rem;
	color: var(--color-text-muted);
}

.admin-users-page-size select {
	min-height: 2rem;
	border-radius: var(--radius-sm);
	border: 1px solid rgba(15, 23, 42, 0.16);
	padding: 0.25rem 0.45rem;
}

.admin-users-page-nav {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.admin-users-page-indicator {
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

@media (min-width: 920px) {
	.admin-users-list-grid {
		grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	}
}

.admin-user-card {
	background: #ffffff;
	border-radius: var(--radius-md);
	border: 1px solid rgba(15, 23, 42, 0.08);
	box-shadow: 0 24px 48px -32px rgba(15, 23, 42, 0.25);
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	padding: 1.05rem 1.1rem;
}

.admin-user-card-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.admin-user-card-header h3 {
	margin: 0;
	font-size: 1rem;
	color: var(--color-text-main);
}

.admin-user-card-header p {
	margin: 0.25rem 0 0;
	color: var(--color-text-muted);
	font-size: 0.9rem;
}

.admin-user-card-meta {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	color: var(--color-text-muted);
	font-size: 0.85rem;
}

.admin-user-card-meta span {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
}

.admin-user-card-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	align-items: center;
}

.admin-user-card-memberships {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.admin-user-card-memberships-label {
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-text-muted);
}

.admin-user-card-memberships-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem;
}

.admin-user-membership-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.2rem 0.5rem;
	border-radius: var(--radius-full);
	background: rgba(37, 99, 235, 0.08);
	border: 1px solid rgba(37, 99, 235, 0.2);
	font-size: 0.78rem;
	color: var(--color-primary);
}

.admin-user-membership-pill--empty {
	background: rgba(15, 23, 42, 0.05);
	border-color: rgba(15, 23, 42, 0.12);
	color: var(--color-text-muted);
	font-style: italic;
}

.admin-user-super-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.8rem;
	height: 1.8rem;
	border-radius: 999px;
	color: #b7791f;
	background: rgba(183, 121, 31, 0.12);
	margin-left: 0.35rem;
	font-size: 0.95rem;
}
.admin-user-super-icon i {
	line-height: 1;
}

.admin-users-table-wrapper {
	width: 100%;
	min-width: 0;
	overflow: visible;
}

.admin-users-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	overflow: visible;
}

.admin-users-table th,
.admin-users-table td {
	padding: 0.55rem 0.7rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
	vertical-align: middle;
}

.admin-users-table th {
	text-align: left;
	font-size: 0.85rem;
	color: var(--color-text-muted);
	font-weight: 600;
	letter-spacing: 0.02em;
	background: rgba(15, 23, 42, 0.02);
}

.admin-users-table tbody tr:hover {
	background: rgba(37, 99, 235, 0.03);
}

.admin-users-table-user {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.admin-users-table-name {
	font-weight: 600;
	color: var(--color-text-main);
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}

.admin-users-table-email {
	color: var(--color-text-muted);
	font-size: 0.85rem;
}

.admin-users-table-memberships {
	max-width: 520px;
	white-space: normal;
}

.admin-users-table-memberships .admin-user-membership-pill {
	margin: 0.1rem 0.1rem 0 0;
}

.admin-users-table-actions-col {
	width: 140px;
	white-space: nowrap;
}

.admin-users-table-actions {
	display: table-cell;
	text-align: right;
	vertical-align: middle;
}

.admin-users-table-actions .btn-icon + .btn-icon {
	margin-left: 0.35rem;
}

.admin-user-card-actions .btn-icon,
.admin-users-table-actions .btn-icon {
	padding: 0.45rem;
	border-radius: var(--radius-sm);
	min-width: auto;
}

.admin-users-password-field {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	align-items: flex-start;
}

.admin-users-password-field input {
	flex: 1 1 240px;
	min-width: 0;
}

.admin-users-password-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.admin-users-password-actions .btn {
	padding: 0.55rem 0.9rem;
	font-size: 0.85rem;
	gap: 0.35rem;
	box-shadow: none;
}

.admin-users-password-actions .btn i {
	font-size: 0.85rem;
}

.admin-users-editor-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	font-size: 0.95rem;
	color: var(--color-text-main);
}

.admin-users-membership-picker {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.admin-users-memberships-feedback {
	margin: 0;
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.admin-users-memberships-feedback[data-error='true'] {
	color: var(--color-danger);
}

.admin-users-memberships-list {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.admin-users-membership-row {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
	gap: 0.25rem 0.5rem;
	align-items: start;
	padding: 0.35rem 0.5rem 0.45rem;
	border: 1px solid rgba(15, 23, 42, 0.06);
	border-radius: var(--radius-sm);
	background: #ffffff;
}

.admin-users-membership-grid {
	display: contents;
}

.admin-users-membership-field {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.admin-users-membership-label {
	display: block;
	color: var(--color-text-muted);
	font-size: 0.78rem;
	line-height: 1.2;
}

.admin-users-membership-field select {
	width: 100%;
	min-height: 2rem;
	border-radius: var(--radius-sm);
	border: 1px solid rgba(15, 23, 42, 0.16);
	padding: 0.3rem 0.5rem;
	background: #ffffff;
}

.admin-users-membership-toggle-field {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	align-self: start;
}

.admin-users-membership-toggle {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.82rem;
	color: var(--color-text-main);
}

.admin-users-membership-toggle input[type='checkbox'] {
	margin: 0;
}

.admin-users-membership-actions {
	align-self: start;
	display: flex;
	justify-content: flex-end;
	padding-top: 0.9rem;
}

.admin-users-memberships-empty {
	margin: 0;
	font-size: 0.9rem;
	color: var(--color-text-muted);
	font-style: italic;
}

.admin-users-membership-row .btn-icon {
	width: max-content;
	justify-self: end;
	padding: 0.35rem;
	border-radius: var(--radius-sm);
}

.admin-users-membership-row .btn-icon:hover,
.admin-users-membership-row .btn-icon:focus-visible {
	background: rgba(15, 23, 42, 0.06);
	outline: none;
}

@media (max-width: 880px) {
	.admin-users-membership-row {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		align-items: start;
	}

	.admin-users-membership-row .btn-icon {
		justify-self: start;
	}
}

.admin-users-editor-checkbox input[type='checkbox'] {
	margin-top: 0.2rem;
}

.admin-users-editor-checkbox span {
	text-transform: none;
	letter-spacing: normal;
	color: inherit;
	font-size: 0.95rem;
}

.admin-users-editor {
	position: fixed;
	inset: 0;
	display: none;
	z-index: 1300;
}

.admin-users-editor[data-open='true'] {
	display: block;
}

.admin-users-editor-modal {
	width: min(640px, 100%);
	max-height: min(94vh, 100%);
	display: flex;
	flex-direction: column;
}

.admin-users-editor-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.admin-users-editor-header h2 {
	margin: 0;
}

.admin-users-editor-form {
	display: flex;
	flex-direction: column;
	gap: 1.2rem;
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	padding: 1.5rem 1.75rem 1.75rem;
}

.admin-users-editor-feedback {
	padding: 0.85rem 1rem;
	border-radius: var(--radius-sm);
	background: rgba(185, 28, 28, 0.12);
	color: var(--color-danger);
	border: 1px solid rgba(185, 28, 28, 0.18);
	font-size: 0.9rem;
}

.admin-users-editor-actions {
	display: flex;
	gap: 0.75rem;
	justify-content: flex-end;
}

.admin-users-editor-actions [data-editor-submit-label] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.admin-users-editor-actions [data-editor-submit] {
	min-width: 180px;
}

/* Survey run */
.page.survey-run {
	max-width: 720px;
	margin: 0 auto;
	padding: clamp(1.5rem, 5vw, 3rem);
	display: flex;
	flex-direction: column;
	gap: clamp(1.25rem, 4vw, 2rem);
	background: linear-gradient(180deg, rgba(248, 250, 252, 0.8) 0%, rgba(241, 245, 249, 0.4) 100%);
	min-height: 100vh;
}

.survey-run-header {
	text-align: center;
	padding: clamp(1.25rem, 3vw, 2rem) clamp(1rem, 3vw, 2rem);
	background: linear-gradient(135deg, var(--color-primary) 0%, #4f46e5 100%);
	border-radius: var(--radius-lg);
	color: #ffffff;
	box-shadow: 0 20px 40px -20px rgba(37, 99, 235, 0.4);
}

.survey-run-header h1 {
	margin: 0 0 0.5rem;
	font-size: clamp(1.35rem, 4vw, 1.75rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: inherit;
}

.survey-run-header p {
	margin: 0;
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.6;
	font-size: 0.95rem;
}

.survey-run-badge {
	display: inline-block;
	margin-top: 0.75rem;
	padding: 0.35rem 0.85rem;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	font-size: 0.85rem;
	font-weight: 500;
	backdrop-filter: blur(4px);
}

.survey-run-description {
	opacity: 0.9;
}

.survey-run-questions {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.survey-run-card {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.06);
	border-radius: var(--radius-lg);
	padding: clamp(1.25rem, 3vw, 1.75rem);
	box-shadow: 
		0 1px 3px rgba(15, 23, 42, 0.04),
		0 8px 24px -8px rgba(15, 23, 42, 0.08);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.survey-run-card:hover {
	box-shadow: 
		0 1px 3px rgba(15, 23, 42, 0.04),
		0 12px 32px -8px rgba(15, 23, 42, 0.12);
}

.survey-run-card:focus-within {
	box-shadow: 
		0 0 0 3px rgba(37, 99, 235, 0.15),
		0 12px 32px -8px rgba(15, 23, 42, 0.12);
}

.survey-run-question {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.survey-run-question h3 {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--color-text);
	line-height: 1.4;
}

.survey-run-question-desc {
	margin: -0.25rem 0 0.5rem;
	color: var(--color-text-muted);
	font-size: 0.9rem;
	line-height: 1.5;
}

.survey-run-options {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

.survey-run-option {
	position: relative;
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 0.85rem 1rem 0.85rem 3rem;
	display: flex;
	align-items: center;
	background: #fafbfc;
	cursor: pointer;
	transition: all 0.15s ease;
	font-size: 0.95rem;
}

.survey-run-option:hover {
	border-color: var(--color-primary);
	background: rgba(37, 99, 235, 0.03);
}

.survey-run-option:has(input:checked) {
	border-color: var(--color-primary);
	background: rgba(37, 99, 235, 0.06);
}

.survey-run-option input {
	position: absolute;
	left: 1rem;
	margin: 0;
	width: 18px;
	height: 18px;
	accent-color: var(--color-primary);
	cursor: pointer;
}

.survey-run-option input[type="checkbox"] {
	border-radius: 4px;
}

.survey-run-option span {
	flex: 1;
	line-height: 1.4;
}

.survey-run-scale {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.survey-run-scale-labels {
	display: flex;
	justify-content: space-between;
	color: var(--color-text-muted);
	font-size: 0.85rem;
	font-weight: 500;
	padding: 0 0.25rem;
}

.survey-run-scale-options {
	display: flex;
	justify-content: space-between;
	width: 100%;
	gap: 0.35rem;
}

.survey-run-scale-radio {
	position: relative;
	border: 2px solid var(--color-border);
	border-radius: var(--radius-sm);
	padding: 0;
	background: #ffffff;
	cursor: pointer;
	transition: all 0.15s ease;
	overflow: hidden;
	flex: 1;
	max-width: 56px;
}

.survey-run-scale-radio input {
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
	pointer-events: none;
}

.survey-run-scale-radio span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	min-height: 36px;
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--color-text-muted);
	transition: all 0.15s ease;
}

.survey-run-scale-radio:hover {
	border-color: var(--color-primary);
	background: rgba(37, 99, 235, 0.04);
}

.survey-run-scale-radio:hover span {
	color: var(--color-primary);
}

.survey-run-scale-radio:has(input:checked) {
	border-color: var(--color-primary);
	background: var(--color-primary);
}

.survey-run-scale-radio:has(input:checked) span {
	color: #ffffff;
}

.survey-run-form textarea {
	width: 100%;
	border-radius: var(--radius-md);
	border: 2px solid var(--color-border);
	padding: 0.85rem 1rem;
	font: inherit;
	font-size: 0.95rem;
	resize: vertical;
	min-height: 100px;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	background: #fafbfc;
}

.survey-run-form textarea:hover {
	border-color: rgba(37, 99, 235, 0.4);
}

.survey-run-form textarea:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
	background: #ffffff;
}

.survey-run-form textarea::placeholder {
	color: var(--color-text-muted);
	opacity: 0.7;
}

.survey-run-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.5rem;
	padding-top: 1rem;
}

.survey-run-actions .btn {
	min-width: 220px;
	padding: 0.9rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	background: linear-gradient(135deg, var(--color-primary) 0%, #4f46e5 100%);
	border: none;
	box-shadow: 0 8px 24px -8px rgba(37, 99, 235, 0.5);
	transition: all 0.2s ease;
}

.survey-run-actions .btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 32px -8px rgba(37, 99, 235, 0.6);
}

.survey-run-actions .btn:active {
	transform: translateY(0);
}

.survey-run-note {
	font-size: 0.85rem;
	color: var(--color-text-muted);
	text-align: center;
	margin: 0;
}

.survey-run-hint {
	text-align: center;
	color: var(--color-text-muted);
	font-size: 0.95rem;
	padding: 1.5rem;
	background: rgba(148, 163, 184, 0.08);
	border-radius: var(--radius-md);
	margin: 0;
}

.survey-run-feedback {
	min-height: 1.25rem;
	font-size: 0.95rem;
	text-align: center;
	font-weight: 500;
}

.survey-run-feedback[data-tone='error'] {
	color: #dc2626;
}

.survey-run-feedback[data-tone='success'] {
	color: #16a34a;
}

/* Survey Success Modal */
.survey-success-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	animation: fadeIn 0.2s ease;
}

.survey-success-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.6);
	backdrop-filter: blur(4px);
}

.survey-success-content {
	position: relative;
	background: #ffffff;
	border-radius: var(--radius-lg);
	padding: 2.5rem;
	max-width: 420px;
	width: 100%;
	text-align: center;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
	animation: slideUp 0.3s ease;
}

@keyframes slideUp {
	from {
		opacity: 0;
		transform: translateY(20px) scale(0.95);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.survey-success-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto 1.5rem;
	border-radius: 50%;
	background: linear-gradient(135deg, #10b981 0%, #059669 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 10px 30px -5px rgba(16, 185, 129, 0.4);
}

.survey-success-icon i {
	font-size: 2.5rem;
	color: #ffffff;
}

.survey-success-content h2 {
	margin: 0 0 0.75rem;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-text-main);
}

.survey-success-content p {
	margin: 0 0 2rem;
	font-size: 1rem;
	color: var(--color-text-muted);
	line-height: 1.5;
}

.survey-success-actions {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.survey-success-actions .btn {
	width: 100%;
	justify-content: center;
}

@media (min-width: 480px) {
	.survey-success-actions {
		flex-direction: row;
		justify-content: center;
	}

	.survey-success-actions .btn {
		width: auto;
		min-width: 160px;
	}
}

.survey-run-choice {
	border: 1px solid rgba(15, 23, 42, 0.06);
	border-radius: var(--radius-lg);
	padding: 1.25rem 1.5rem;
	background: #ffffff;
	box-shadow: 
		0 1px 3px rgba(15, 23, 42, 0.04),
		0 8px 24px -8px rgba(15, 23, 42, 0.08);
	display: grid;
	gap: 1rem;
}

.survey-run-choice > p {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
	line-height: 1.5;
}

.survey-run-choice-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.survey-run-choice .btn {
	background: linear-gradient(135deg, var(--color-primary) 0%, #4f46e5 100%);
	color: #ffffff;
	border: none;
	box-shadow: 0 8px 20px -8px rgba(37, 99, 235, 0.5);
	min-width: 160px;
	font-weight: 500;
	transition: all 0.2s ease;
}

.survey-run-choice .btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 24px -8px rgba(37, 99, 235, 0.6);
}

.survey-run-choice .btn-ghost {
	background: rgba(37, 99, 235, 0.08);
	color: var(--color-primary);
	border: 1px solid rgba(37, 99, 235, 0.2);
	box-shadow: none;
}

.survey-run-choice .btn-ghost:hover {
	background: rgba(37, 99, 235, 0.12);
	transform: none;
}

/* Survey run name section */
.survey-run-name {
	border-left: 4px solid var(--color-primary);
	margin-bottom: 0.5rem;
}

.survey-run-name-header h4 {
	margin: 0 0 0.25rem;
	font-size: 1rem;
	font-weight: 600;
}

.survey-run-name input[type="text"] {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	font: inherit;
	font-size: 0.95rem;
	background: #fafbfc;
	transition: all 0.15s ease;
}

.survey-run-name input[type="text"]:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
	background: #ffffff;
}

.survey-run-eyebrow {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	opacity: 0.8;
	margin: 0 0 0.25rem;
}

.survey-run-error {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
	padding: 2rem;
	background: rgba(220, 38, 38, 0.06);
	border: 1px solid rgba(220, 38, 38, 0.15);
	border-radius: var(--radius-lg);
	color: #dc2626;
	text-align: center;
}

.survey-run-error i {
	font-size: 1.5rem;
}

.survey-run-error p {
	margin: 0;
}

/* Doodle run */
.doodle-run-container {
	padding: clamp(1.5rem, 4vw, 2.5rem);
}

.doodle-header {
	margin-bottom: 1.5rem;
}

.doodle-header h1 {
	margin: 0 0 0.5rem;
}

.doodle-description {
	color: var(--color-text-muted);
	margin: 0;
}

.doodle-form {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-lg);
	padding: clamp(1rem, 2vw, 1.5rem);
	box-shadow: 0 16px 38px -24px rgba(15, 23, 42, 0.25);
}

.slots-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.slot-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding: 0.75rem 1rem;
	background: #fafbff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	flex-wrap: wrap;
}

.slot-info {
	flex: 1;
	min-width: 200px;
}

.slot-date {
	font-weight: 500;
	text-transform: capitalize;
}

.slot-time {
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.slot-actions {
	display: flex;
	gap: 0.5rem;
}

.availability-btn {
	width: 40px;
	height: 40px;
	border-radius: var(--radius-md);
	border: 2px solid var(--color-border);
	background: #ffffff;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 0.15s ease;
}

.availability-btn:hover:not(:disabled) {
	border-color: var(--color-primary);
	background: rgba(37, 99, 235, 0.08);
}

.availability-btn[data-availability='yes'].active {
	background: #22c55e;
	border-color: #16a34a;
	color: #ffffff;
}

.availability-btn[data-availability='maybe'].active {
	background: #f59e0b;
	border-color: #d97706;
	color: #ffffff;
}

.availability-btn[data-availability='no'].active {
	background: #ef4444;
	border-color: #dc2626;
	color: #ffffff;
}

.availability-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Participations grid */
.participations-grid-wrapper {
	margin-top: 2rem;
}

.participations-grid {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.participations-grid th,
.participations-grid td {
	padding: 0.75rem;
	text-align: center;
	border-bottom: 1px solid var(--color-border);
}

.participations-grid th {
	background: #f8fafc;
	font-weight: 500;
}

.participations-grid .slot-label {
	text-align: left;
	min-width: 180px;
}

.participations-grid .slot-label .slot-date {
	font-weight: 500;
	text-transform: capitalize;
}

.participations-grid .slot-label .slot-time {
	font-size: 0.85rem;
	color: var(--color-text-muted);
}

.participations-grid .participant-name {
	min-width: 100px;
	max-width: 150px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.participations-grid .availability-cell {
	font-size: 1rem;
}

.participations-grid .availability-cell.success {
	color: #16a34a;
}

.participations-grid .availability-cell.warning {
	color: #d97706;
}

.participations-grid .availability-cell.danger {
	color: #dc2626;
}

.participations-grid .availability-cell.unknown {
	color: #94a3b8;
}

.participations-empty {
	background: #f8fafc;
	border: 1px dashed var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
}

.auth-banner {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	border-radius: var(--radius-md);
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	color: #1e40af;
}

.auth-banner i {
	flex-shrink: 0;
}

.info-box {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	border-radius: var(--radius-md);
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	color: #1e40af;
}

.info-box.success {
	background: #f0fdf4;
	border-color: #86efac;
	color: #166534;
}

.doodle-run-success {
	text-align: center;
	padding: 2rem;
}

.doodle-run-success h2 {
	margin: 0 0 0.5rem;
}

.doodle-run-success p {
	margin: 0;
	color: var(--color-text-muted);
}

/* ========================================
   Results Pages (Survey & Doodle Results)
   ======================================== */

.page.results {
	display: flex;
	flex-direction: column;
	gap: clamp(1.5rem, 4vw, 2.5rem);
	padding-bottom: 3rem;
}

.results-loader {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 4rem 2rem;
	color: var(--color-text-muted);
}

.results-error {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 4rem 2rem;
	text-align: center;
	color: var(--color-text-muted);
}

.results-error i {
	font-size: 2.5rem;
	color: #ef4444;
}

.results-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 4rem 2rem;
	text-align: center;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
}

.results-empty i {
	font-size: 3rem;
	color: var(--color-text-muted);
	opacity: 0.5;
}

.results-empty h3 {
	margin: 0;
	font-size: 1.25rem;
	color: var(--color-text-main);
}

.results-empty p {
	margin: 0;
	color: var(--color-text-muted);
}

.results-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.results-title-section {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
}

.results-title-text h1 {
	margin: 0;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--color-text-main);
}

.results-subtitle {
	margin: 0.25rem 0 0;
	color: var(--color-text-muted);
	font-size: 0.95rem;
}

.results-actions {
	display: flex;
	gap: 0.75rem;
}

/* Light Stats Mode */
.results-stats-light {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	padding: 1rem 1.25rem;
}

.stats-summary {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.stats-main {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1rem;
	color: var(--color-text-main);
}

.stats-main i {
	color: var(--color-primary);
}

.stats-main strong {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-primary);
}

.stats-separator {
	color: var(--color-text-muted);
	opacity: 0.5;
}

.stats-detail {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.9rem;
	color: var(--color-text-muted);
}

.stats-detail i {
	font-size: 0.85rem;
}

.stats-actions {
	display: flex;
	gap: 0.5rem;
}

/* Advanced Stats Container */
.results-stats-advanced {
	margin-top: 1rem;
	animation: fadeIn 0.2s ease;
}

@keyframes fadeIn {
	from { opacity: 0; transform: translateY(-5px); }
	to { opacity: 1; transform: translateY(0); }
}

.results-stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1rem;
}

.results-stats .stat-card {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	padding: 1.25rem;
	display: flex;
	align-items: center;
	gap: 1rem;
}

.results-stats .stat-card.stat-primary {
	background: linear-gradient(135deg, var(--color-primary) 0%, #4f46e5 100%);
	border: none;
	color: #ffffff;
}

.results-stats .stat-card.stat-primary .stat-icon {
	background: rgba(255, 255, 255, 0.2);
	color: #ffffff;
}

.results-stats .stat-card.stat-primary .stat-value,
.results-stats .stat-card.stat-primary .stat-label {
	color: #ffffff;
}

.results-stats .stat-icon {
	width: 48px;
	height: 48px;
	border-radius: var(--radius-md);
	background: rgba(37, 99, 235, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	color: var(--color-primary);
	flex-shrink: 0;
}

.results-stats .stat-content {
	flex: 1;
}

.results-stats .stat-card.best-slot {
	background: linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(16, 185, 129, 0.05) 100%);
	border-color: rgba(16, 185, 129, 0.3);
}

.results-stats .stat-value {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--color-text-main);
	line-height: 1.2;
}

.results-stats .best-slot .stat-value {
	color: #10b981;
}

.results-stats .stat-label {
	font-size: 0.85rem;
	color: var(--color-text-muted);
	margin-top: 0.15rem;
}

.results-stats .stat-detail {
	font-size: 0.75rem;
	color: var(--color-text-muted);
	margin-top: 0.5rem;
	padding-top: 0.5rem;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.results-view-toggle {
	display: flex;
	justify-content: center;
	margin-top: 0.5rem;
}

/* Results Section Titles */
.results-section-title {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--color-text-main);
	margin: 0 0 1rem;
}

.results-section-title i {
	color: var(--color-primary);
}

.results-responses-section,
.results-charts-section,
.results-heatmap-section {
	margin-top: 1.5rem;
}

/* Question Charts */
.results-charts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 1rem;
}

.question-chart-card {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.question-chart-header {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 1rem 1.25rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.question-chart-header .question-number {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--color-primary);
	color: #ffffff;
	font-size: 0.75rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	justify-content: center;
}

.question-chart-header h4 {
	margin: 0;
	font-size: 0.95rem;
	font-weight: 500;
	line-height: 1.4;
	color: var(--color-text-main);
}

.question-chart-body {
	padding: 1rem 1.25rem;
}

.question-chart-footer {
	padding: 0.75rem 1.25rem;
	background: rgba(15, 23, 42, 0.02);
	font-size: 0.8rem;
	color: var(--color-text-muted);
}

/* Bar Charts */
.chart-bars {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

.chart-bar-row {
	display: grid;
	grid-template-columns: 1fr 2fr auto;
	gap: 0.75rem;
	align-items: center;
}

.chart-bar-label {
	font-size: 0.85rem;
	color: var(--color-text-main);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.chart-bar-track {
	height: 24px;
	background: rgba(15, 23, 42, 0.06);
	border-radius: 4px;
	overflow: hidden;
}

.chart-bar-fill {
	height: 100%;
	border-radius: 4px;
	transition: width 0.3s ease;
	min-width: 4px;
}

.chart-bar-value {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-text-main);
	min-width: 60px;
	text-align: right;
}

.chart-bar-percent {
	font-weight: 400;
	color: var(--color-text-muted);
}

/* Scale Charts */
.scale-chart {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.scale-average {
	text-align: center;
	padding: 0.75rem;
	background: rgba(37, 99, 235, 0.06);
	border-radius: var(--radius-md);
}

.scale-average-value {
	display: block;
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-primary);
}

.scale-average-label {
	font-size: 0.8rem;
	color: var(--color-text-muted);
}

.scale-bars {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	height: 80px;
	gap: 0.5rem;
}

.scale-bar-col {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	height: 100%;
}

.scale-bar-fill {
	width: 100%;
	max-width: 40px;
	background: linear-gradient(180deg, var(--color-primary) 0%, #4f46e5 100%);
	border-radius: 4px 4px 0 0;
	margin-top: auto;
	transition: height 0.3s ease;
}

.scale-bar-label {
	margin-top: 0.5rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--color-text-muted);
}

/* Heatmap - New Row-based Layout */
.heatmap-list {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	max-width: 100%;
}

.heatmap-row {
	display: flex;
	align-items: stretch;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
	min-width: max-content;
	max-width: 1200px;
}

.heatmap-row:last-child {
	border-bottom: none;
}

.heatmap-question {
	flex: 0 0 280px;
	min-width: 200px;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1rem;
	background: #f8fafc;
	border-right: 1px solid rgba(15, 23, 42, 0.06);
	position: sticky;
	left: 0;
	z-index: 1;
	box-shadow: 2px 0 4px rgba(15, 23, 42, 0.05);
}

.heatmap-question .question-number {
	flex-shrink: 0;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--color-primary);
	color: #ffffff;
	font-size: 0.7rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	justify-content: center;
}

.heatmap-question .question-title {
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--color-text-main);
	line-height: 1.4;
}

.heatmap-options,
.heatmap-scale {
	flex: 1;
	display: flex;
	align-items: stretch;
	gap: 2px;
	padding: 0.5rem;
	min-width: 300px;
}

.heatmap-option {
	flex: 1;
	min-width: 80px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 0.6rem 0.5rem;
	border-radius: 6px;
	text-align: center;
	min-width: 80px;
	transition: transform 0.15s ease;
}

.heatmap-option:hover {
	transform: scale(1.02);
}

.heatmap-option-label {
	font-size: 0.75rem;
	font-weight: 500;
	margin-bottom: 0.25rem;
	line-height: 1.2;
}

.heatmap-option-value {
	font-size: 1rem;
	font-weight: 700;
}

.heatmap-scale {
	gap: 4px;
}

.heatmap-scale-item {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 0.75rem;
	border-radius: 6px;
	min-width: 50px;
}

.heatmap-scale-item .scale-value {
	font-size: 1rem;
	font-weight: 700;
}

.heatmap-scale-item .scale-percent {
	font-size: 0.7rem;
	opacity: 0.9;
}

.heatmap-average {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 1rem;
	margin-left: auto;
	background: rgba(37, 99, 235, 0.1);
	border-radius: 6px;
}

.heatmap-average .average-label {
	font-size: 0.65rem;
	font-weight: 600;
	color: var(--color-text-muted);
	text-transform: uppercase;
}

.heatmap-average .average-value {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-primary);
}

.heatmap-text-info {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 1rem;
	color: var(--color-text-muted);
	font-style: italic;
}

.heatmap-text-info i {
	font-size: 1rem;
}

.heatmap-legend {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	padding: 1rem;
	margin-top: 1rem;
}

.legend-label {
	font-size: 0.8rem;
	color: var(--color-text-muted);
	font-weight: 500;
}

.legend-gradient {
	width: 150px;
	height: 16px;
	border-radius: 4px;
	background: linear-gradient(90deg, rgba(59, 130, 246, 0.15) 0%, rgba(59, 130, 246, 0.9) 100%);
}

/* Heatmap Mobile Responsive */
@media (max-width: 768px) {
	.heatmap-question {
		flex: 0 0 180px;
		min-width: 150px;
		padding: 0.75rem;
	}

	.heatmap-question .question-title {
		font-size: 0.8rem;
	}

	.heatmap-option {
		min-width: 70px;
		padding: 0.5rem 0.35rem;
	}

	.heatmap-option-label {
		font-size: 0.7rem;
	}

	.heatmap-option-value {
		font-size: 0.85rem;
	}

	.heatmap-scale-item {
		min-width: 40px;
		padding: 0.4rem 0.5rem;
	}

	.results-stats-light {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.stats-summary {
		flex-wrap: wrap;
	}

	.stats-actions {
		width: 100%;
		justify-content: flex-start;
	}
}

/* Answer Item with Question Number */
.answer-item .question-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--color-primary);
	color: #ffffff;
	font-size: 0.65rem;
	font-weight: 600;
	margin-right: 0.5rem;
	vertical-align: middle;
}

.answer-scale-hint {
	font-size: 0.8rem;
	color: var(--color-text-muted);
	font-weight: 400;
}

/* Bullet points for multiple choice */
.answer-bullet {
	color: var(--color-primary);
	font-weight: 700;
	margin-right: 0.35rem;
}

/* Survey Results Table */
.results-table-container {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	overflow: visible;
}

.results-table {
	width: 100%;
	border-collapse: collapse;
}

.results-table thead {
	background: rgba(15, 23, 42, 0.03);
}

.results-table th {
	padding: 0.85rem 1rem;
	font-size: 0.8rem;
	font-weight: 600;
	text-align: left;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--color-text-muted);
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.response-row {
	transition: background 0.15s;
}

.response-row:hover {
	background: rgba(37, 99, 235, 0.04);
}

.response-row td {
	padding: 0.85rem 1rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
	vertical-align: middle;
}

.response-row:last-child td {
	border-bottom: none;
}

.response-cell-number {
	width: 50px;
	color: var(--color-text-muted);
	font-weight: 600;
}

.response-cell-respondent {
	min-width: 200px;
}

.respondent-name {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 500;
	color: var(--color-text-main);
}

.respondent-icon {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: help;
}

/* Tooltip z-index élevé pour être par-dessus le tableau */
.respondent-icon.tooltip-trigger::after {
	z-index: 1000;
}

.respondent-icon.tooltip-trigger::before {
	z-index: 1000;
}

.respondent-name i {
	color: var(--color-text-muted);
	width: 18px;
	text-align: center;
}

/* Authenticated user (verified) */
.respondent-name.authenticated i {
	color: #10b981;
}

/* Free identifier (not verified) */
.respondent-name.free-id i {
	color: #f59e0b;
}

/* Anonymous */
.respondent-name.anonymous {
	color: var(--color-text-muted);
	font-style: italic;
}

.respondent-name.anonymous i {
	color: var(--color-text-muted);
}

.response-cell-date {
	color: var(--color-text-muted);
	font-size: 0.9rem;
}

.response-cell-actions {
	width: 80px;
	text-align: right;
}

/* Response Detail Modal */
.response-detail-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}

.response-detail-modal .modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.5);
	cursor: pointer;
}

.response-detail-modal .modal-content {
	position: relative;
	background: #ffffff;
	border-radius: var(--radius-lg);
	max-width: 600px;
	width: 100%;
	max-height: 80vh;
	display: flex;
	flex-direction: column;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.response-detail-modal .modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem 1.5rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.response-detail-modal .modal-header h3 {
	margin: 0;
	font-size: 1.1rem;
}

.response-detail-modal .modal-body {
	padding: 1.5rem;
	overflow-y: auto;
	flex: 1;
}

.response-detail-modal .modal-footer {
	display: flex;
	justify-content: flex-end;
	padding: 1rem 1.5rem;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.response-meta {
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.response-meta p {
	margin: 0 0 0.5rem;
	font-size: 0.9rem;
}

.response-answers {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.answer-item {
	padding: 0.75rem;
	background: rgba(15, 23, 42, 0.02);
	border-radius: var(--radius-sm);
}

.answer-question {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-text-main);
	margin-bottom: 0.5rem;
}

.answer-value {
	font-size: 0.95rem;
	color: var(--color-text-main);
}

.no-answers {
	color: var(--color-text-muted);
	font-style: italic;
}

/* Doodle Results - Availability Matrix */
.availability-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	padding: 1rem 1.25rem;
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
}

.legend-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.85rem;
	color: var(--color-text-muted);
}

.availability-matrix-container {
	background: #ffffff;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: var(--radius-md);
	overflow-x: auto;
}

.availability-matrix {
	width: 100%;
	border-collapse: collapse;
	min-width: 600px;
}

.availability-matrix thead {
	background: rgba(15, 23, 42, 0.03);
}

.availability-matrix th {
	padding: 0.85rem 1rem;
	font-size: 0.8rem;
	font-weight: 600;
	text-align: center;
	color: var(--color-text-muted);
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.availability-matrix .th-participant {
	text-align: left;
	min-width: 150px;
}

.availability-matrix .th-slot {
	min-width: 120px;
}

.availability-matrix .th-slot.best-slot {
	background: rgba(16, 185, 129, 0.1);
}

.slot-date {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: capitalize;
}

.slot-time {
	font-size: 0.7rem;
	font-weight: 400;
	margin-top: 0.25rem;
}

.participant-row {
	transition: background 0.15s;
}

.participant-row:hover {
	background: rgba(37, 99, 235, 0.04);
}

.participant-row td {
	padding: 0.75rem 1rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.participant-row:last-child td {
	border-bottom: none;
}

.participant-name {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 500;
	color: var(--color-text-main);
}

.participant-name i {
	color: var(--color-text-muted);
}

.availability-cell {
	text-align: center;
	font-size: 1.1rem;
}

.availability-cell.best-slot {
	background: rgba(16, 185, 129, 0.05);
}

.availability-cell i {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
}

.availability-yes {
	color: #10b981;
	background: rgba(16, 185, 129, 0.15);
}

.availability-no {
	color: #ef4444;
	background: rgba(239, 68, 68, 0.15);
}

.availability-maybe {
	color: #f59e0b;
	background: rgba(245, 158, 11, 0.15);
}

.availability-unknown {
	color: var(--color-text-muted);
	background: rgba(15, 23, 42, 0.08);
}

.availability-matrix tfoot {
	background: rgba(15, 23, 42, 0.03);
}

.totals-row td {
	padding: 0.85rem 1rem;
	font-weight: 600;
	border-top: 2px solid rgba(15, 23, 42, 0.1);
}

.totals-label {
	color: var(--color-text-main);
}

.totals-cell {
	text-align: center;
}

.totals-cell.best-slot {
	background: rgba(16, 185, 129, 0.1);
}

.total-yes {
	color: #10b981;
	font-size: 1.1rem;
}

.total-separator {
	color: var(--color-text-muted);
	margin: 0 0.1rem;
}

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

.no-slots {
	padding: 2rem;
	text-align: center;
	color: var(--color-text-muted);
}
