/**
 * AI Website Builder — front-end shortcodes (scoped to .aiwb-* classes only).
 *
 * Shared design tokens on major roots (no global :root pollution).
 */

.aiwb-fe,
.aiwb-dash,
.aiwb-user-dashboard,
.aiwb-project-form,
.aiwb-homepage-form,
.aiwb-builder-page-form,
.aiwb-gen-preview,
.aiwb-render-page {
	--aiwb-fe-accent: #1d6baf;
	--aiwb-fe-accent-hover: #155a94;
	--aiwb-fe-surface: #ffffff;
	--aiwb-fe-muted: #5c5c5c;
	--aiwb-fe-border: rgba(15, 23, 42, 0.1);
	--aiwb-fe-radius: 10px;
	--aiwb-fe-shadow: 0 1px 2px rgba(15, 23, 42, 0.06), 0 4px 12px rgba(15, 23, 42, 0.04);
	--aiwb-fe-focus: #1d6baf;
}

/**
 * Front-end shortcode shell (minimal; themes may override).
 */
.aiwb-fe {
	max-width: 960px;
	margin: 0 auto 1.5rem;
	padding: 1rem 1.25rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: var(--aiwb-fe-radius);
	background: var(--aiwb-fe-surface);
	box-shadow: var(--aiwb-fe-shadow);
	box-sizing: border-box;
}

.aiwb-fe .aiwb-fe__message {
	margin: 0 0 0.75rem;
}

.aiwb-fe .form-table th {
	width: 12rem;
	vertical-align: top;
}

.aiwb-fe .aiwb-fe__header {
	margin-bottom: 1.25rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--aiwb-fe-border);
}

.aiwb-fe .aiwb-fe__title {
	margin: 0 0 0.35rem;
	font-size: clamp(1.2rem, 2.5vw, 1.45rem);
	line-height: 1.25;
	font-weight: 700;
	color: #0f172a;
}

.aiwb-fe .aiwb-fe__notice {
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	border-radius: 8px;
	border: 1px solid rgba(214, 54, 56, 0.35);
	background: #fcf0f1;
	color: #3c1f1f;
}

.aiwb-fe .aiwb-project-nav {
	margin: 0 0 1.25rem;
}

.aiwb-fe .aiwb-project-nav__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.65rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.aiwb-fe .aiwb-project-nav__item {
	margin: 0;
}

.aiwb-fe .aiwb-project-nav__link {
	display: inline-block;
	padding: 0.45rem 0.85rem;
	border-radius: 999px;
	text-decoration: none;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--aiwb-fe-accent);
	border: 1px solid var(--aiwb-fe-border);
	background: #f8fafc;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.aiwb-fe .aiwb-project-nav__link:hover,
.aiwb-fe .aiwb-project-nav__link:focus-visible {
	color: var(--aiwb-fe-accent-hover);
	border-color: rgba(29, 107, 175, 0.35);
	background: #fff;
}

.aiwb-fe .aiwb-project-nav__link.is-active {
	color: #fff;
	background: var(--aiwb-fe-accent);
	border-color: var(--aiwb-fe-accent);
}

.aiwb-fe .aiwb-card {
	padding: 1rem 1.15rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: calc(var(--aiwb-fe-radius) - 2px);
	background: #f8fafc;
	box-sizing: border-box;
}

.aiwb-fe .aiwb-fe__toolbar .submit {
	margin: 0.75rem 0 0;
}

.aiwb-fe .aiwb-fe__toolbar label {
	font-weight: 600;
	margin-right: 0.35rem;
	font-size: 0.9rem;
	color: #334155;
}

.aiwb-fe .aiwb-fe__toolbar select {
	margin-right: 0.5rem;
	padding: 0.4rem 0.6rem;
	border-radius: 6px;
	border: 1px solid var(--aiwb-fe-border);
	font: inherit;
	max-width: 100%;
}

.aiwb-fe .aiwb-fe-preview-wrap {
	margin-top: 1rem;
	padding: 1rem 1.15rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: calc(var(--aiwb-fe-radius) - 2px);
	background: var(--aiwb-fe-surface);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.aiwb-fe .aiwb-fe__links {
	margin: 0 0 1rem 1.1rem;
	padding: 0;
}

.aiwb-fe .aiwb-fe__project-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.aiwb-fe .aiwb-fe__project-list li {
	margin: 0;
	padding: 0.65rem 0.85rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: 8px;
	background: #f8fafc;
}

.aiwb-fe .aiwb-fe__project-list a {
	font-weight: 600;
	text-decoration: none;
	color: var(--aiwb-fe-accent);
}

.aiwb-fe .aiwb-fe__project-list a:hover {
	text-decoration: underline;
}

.aiwb-fe .aiwb-fe__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.95rem;
}

.aiwb-fe .aiwb-fe__table th,
.aiwb-fe .aiwb-fe__table td {
	padding: 0.65rem 0.75rem;
	vertical-align: middle;
}

.aiwb-fe .form-table {
	width: 100%;
	border-collapse: collapse;
}

.aiwb-fe .form-table th {
	width: auto;
	max-width: 11rem;
	padding: 0.75rem 0.75rem 0.75rem 0;
	font-weight: 600;
	color: #334155;
}

.aiwb-fe .form-table td {
	padding: 0.65rem 0;
}

.aiwb-fe .form-table input[type="text"],
.aiwb-fe .form-table input[type="url"],
.aiwb-fe .form-table input[type="email"],
.aiwb-fe .form-table textarea,
.aiwb-fe .form-table select {
	width: 100%;
	max-width: 36rem;
	box-sizing: border-box;
	padding: 0.5rem 0.65rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: 6px;
	font: inherit;
}

.aiwb-fe .notice {
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	border-radius: 8px;
	border-width: 1px;
	border-style: solid;
}

.aiwb-fe .notice.notice-error {
	border-color: rgba(214, 54, 56, 0.45);
	background: #fcf0f1;
}

.aiwb-fe .button,
.aiwb-fe .button-primary,
.aiwb-fe .button-secondary,
.aiwb-fe .button-small {
	display: inline-block;
	padding: 0.55rem 1.1rem;
	border-radius: 8px;
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	cursor: pointer;
	border: 1px solid var(--aiwb-fe-border);
	background: #f1f5f9;
	color: #0f172a;
	line-height: 1.3;
	box-sizing: border-box;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.aiwb-fe .button-primary {
	background: var(--aiwb-fe-accent);
	border-color: var(--aiwb-fe-accent);
	color: #fff;
}

.aiwb-fe .button-primary:hover,
.aiwb-fe .button-primary:focus-visible {
	background: var(--aiwb-fe-accent-hover);
	border-color: var(--aiwb-fe-accent-hover);
	color: #fff;
}

.aiwb-fe .button:hover,
.aiwb-fe .button-secondary:hover,
.aiwb-fe .button-small:hover {
	background: #e2e8f0;
}

.aiwb-fe--guest-teaser .button,
.aiwb-fe--login-required .aiwb-fe__login-link {
	padding: 0.55rem 1.15rem;
	border-radius: 8px;
	font-weight: 600;
	text-decoration: none;
	background: var(--aiwb-fe-accent);
	border: 1px solid var(--aiwb-fe-accent);
	color: #fff;
}

.aiwb-fe--guest-teaser .button:hover,
.aiwb-fe--login-required .aiwb-fe__login-link:hover {
	background: var(--aiwb-fe-accent-hover);
	border-color: var(--aiwb-fe-accent-hover);
	color: #fff;
}

.aiwb-fe :is(a, button, input, select, textarea):focus-visible {
	outline: 2px solid var(--aiwb-fe-focus);
	outline-offset: 2px;
}

.aiwb-fe .aiwb-custom-page-switcher {
	margin-bottom: 1.25rem;
}

.aiwb-fe--login-required .aiwb-fe__login-link {
	display: inline-block;
	text-decoration: none;
}

/* [aiwb_user_dashboard] — legacy compact */
.aiwb-user-dashboard {
	max-width: 720px;
	margin: 0 auto 2rem;
	padding: 1.25rem 1.5rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: var(--aiwb-fe-radius);
	background: var(--aiwb-fe-surface);
	box-shadow: var(--aiwb-fe-shadow);
	box-sizing: border-box;
}

.aiwb-user-dashboard--login-required,
.aiwb-user-dashboard--no-access {
	max-width: 32rem;
}

.aiwb-ud-header {
	margin-bottom: 1.25rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.aiwb-ud-title {
	margin: 0 0 0.35rem;
	font-size: 1.35rem;
}

.aiwb-ud-intro,
.aiwb-ud-lead,
.aiwb-ud-desc {
	margin: 0 0 0.5rem;
	color: #444;
	line-height: 1.5;
}

.aiwb-ud-section {
	margin-bottom: 1.5rem;
}

.aiwb-ud-heading {
	margin: 0 0 0.5rem;
	font-size: 1.1rem;
}

.aiwb-ud-subheading {
	margin: 1rem 0 0.35rem;
	font-size: 1rem;
}

.aiwb-ud-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.aiwb-ud-list--inline {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
}

.aiwb-ud-list__item {
	margin-bottom: 0.65rem;
	padding-bottom: 0.65rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.aiwb-ud-list--inline .aiwb-ud-list__item {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.aiwb-ud-project-name {
	font-weight: 600;
	margin-right: 0.5rem;
}

.aiwb-ud-meta {
	display: block;
	font-size: 0.85rem;
	color: #555;
}

.aiwb-ud-page-label {
	display: block;
	margin: 0.15rem 0;
}

.aiwb-ud-muted {
	font-size: 0.85rem;
	color: #777;
}

.aiwb-ud-empty,
.aiwb-ud-hint {
	margin: 0;
	font-size: 0.95rem;
	color: #666;
}

.aiwb-ud-actions-row {
	margin-bottom: 0.75rem;
}

.aiwb-ud-button {
	display: inline-block;
	padding: 0.5rem 1rem;
	border-radius: 4px;
	text-decoration: none;
	font-weight: 600;
}

.aiwb-ud-button--primary {
	background: var(--aiwb-fe-accent);
	color: #fff;
	border: 1px solid var(--aiwb-fe-accent);
}

.aiwb-ud-button--primary:hover,
.aiwb-ud-button--primary:focus-visible {
	background: var(--aiwb-fe-accent-hover);
	border-color: var(--aiwb-fe-accent-hover);
	color: #fff;
}

.aiwb-ud-list--projects .aiwb-ud-list__item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem 1rem;
	padding: 0.85rem 1rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: 8px;
	background: #f8fafc;
}

.aiwb-ud-list--generated .aiwb-ud-list__item,
.aiwb-ud-list--wp .aiwb-ud-list__item {
	padding-left: 1rem;
	padding-right: 1rem;
}

.aiwb-user-dashboard :is(a, button):focus-visible {
	outline: 2px solid var(--aiwb-fe-focus);
	outline-offset: 2px;
}

.aiwb-ud-link {
	color: var(--aiwb-fe-accent);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.aiwb-ud-link:hover {
	color: var(--aiwb-fe-accent-hover);
}

/* ═══════════════════════════════════════════════════════════════
   [aiwb_user_dashboard] — Modern SaaS Dashboard
   ═══════════════════════════════════════════════════════════════ */

.aiwb-dash {
	--d-primary: #6366f1;
	--d-primary-hover: #4f46e5;
	--d-primary-light: rgba(99, 102, 241, 0.08);
	--d-surface: #ffffff;
	--d-bg: #f4f6fb;
	--d-ink: #0f172a;
	--d-ink-muted: #64748b;
	--d-line: #e2e8f0;
	--d-radius: 14px;
	--d-radius-sm: 10px;
	--d-shadow: 0 1px 3px rgba(15,23,42,0.06), 0 8px 28px -6px rgba(15,23,42,0.1);
	--d-shadow-lg: 0 4px 6px rgba(15,23,42,0.04), 0 20px 50px -10px rgba(15,23,42,0.15);

	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	position: fixed;
	inset: 0;
	z-index: 9999;
	overflow-y: auto;
	overflow-x: hidden;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	background: var(--d-bg);
	color: var(--d-ink);
}

.aiwb-dash *, .aiwb-dash *::before, .aiwb-dash *::after { box-sizing: border-box; }

/* Hide WP admin bar when dashboard is active */
body:has(.aiwb-dash) #wpadminbar,
body:has(.aiwb-dash) .admin-bar #wpadminbar { display: none !important; }
body:has(.aiwb-dash) { margin-top: 0 !important; padding-top: 0 !important; }
body:has(.aiwb-dash) html { margin-top: 0 !important; }
html:has(.aiwb-dash) { margin-top: 0 !important; }

/* ── Gate (login / no-access) ──────────────────── */
.aiwb-dash__gate {
	max-width: 420px;
	margin: 8vh auto;
	padding: 3rem 2rem;
	text-align: center;
	background: var(--d-surface);
	border-radius: var(--d-radius);
	box-shadow: var(--d-shadow);
}
.aiwb-dash__gate-icon { color: var(--d-ink-muted); margin-bottom: 1rem; }
.aiwb-dash__gate h2 { margin: 0 0 0.5rem; font-size: 1.35rem; font-weight: 700; }
.aiwb-dash__gate p { margin: 0 0 1.5rem; color: var(--d-ink-muted); line-height: 1.5; }

/* ── Top bar ───────────────────────────────────── */
.aiwb-dash__topbar {
	flex-shrink: 0;
	background: var(--d-surface);
	border-bottom: 1px solid var(--d-line);
	position: sticky;
	top: 0;
	z-index: 100;
}
.aiwb-dash__topbar-inner {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	max-width: 1360px;
	margin: 0 auto;
	padding: 0 clamp(1rem, 3vw, 2.5rem);
	height: 60px;
}
.aiwb-dash__logo {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	text-decoration: none;
	color: var(--d-ink);
	flex-shrink: 0;
}
.aiwb-dash__logo-text { font-size: 1rem; font-weight: 700; letter-spacing: -0.02em; }
.aiwb-dash__logo-badge {
	font-size: 0.6rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 0.15rem 0.45rem;
	border-radius: 999px;
	background: var(--d-primary-light);
	color: var(--d-primary);
	border: 1px solid rgba(99,102,241,0.15);
}
.aiwb-dash__topnav {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	margin-left: 1.5rem;
}
.aiwb-dash__topnav-link {
	padding: 0.4rem 0.85rem;
	border-radius: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	color: var(--d-ink-muted);
	transition: background 0.15s, color 0.15s;
}
.aiwb-dash__topnav-link:hover { color: var(--d-ink); background: var(--d-primary-light); }
.aiwb-dash__topnav-link.is-active { color: var(--d-primary); background: var(--d-primary-light); }
.aiwb-dash__topnav-link--quiet { color: #94a3b8; font-weight: 500; }
.aiwb-dash__topbar-right {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	margin-left: auto;
}
.aiwb-dash__avatar {
	width: 32px; height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, #818cf8, #6366f1);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.aiwb-dash__username {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--d-ink);
	max-width: 10rem;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* ── Body + Footer ─────────────────────────────── */
.aiwb-dash__body {
	flex: 1;
	padding: clamp(1.25rem, 3vw, 2.5rem) clamp(1rem, 3vw, 2.5rem);
}
.aiwb-dash__body-inner {
	max-width: 1360px;
	margin: 0 auto;
}
.aiwb-dash__footer {
	border-top: 1px solid var(--d-line);
	padding: 1rem clamp(1rem, 3vw, 2.5rem);
}
.aiwb-dash__footer-inner {
	max-width: 1360px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	font-size: 0.8125rem;
	color: var(--d-ink-muted);
}
.aiwb-dash__footer-inner a {
	color: var(--d-primary);
	text-decoration: none;
	font-weight: 600;
}
.aiwb-dash__footer-inner a:hover { text-decoration: underline; }

/* ── Welcome hero ──────────────────────────────── */
.aiwb-dash__welcome { margin-bottom: clamp(1.25rem, 3vw, 2rem); }
.aiwb-dash__welcome h1 {
	margin: 0 0 0.35rem;
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	color: var(--d-ink);
}
.aiwb-dash__welcome p { margin: 0; color: var(--d-ink-muted); font-size: 1rem; line-height: 1.5; }

/* ── Shared button system (pill + optional hover label stack) ─ */
.aiwb-dash__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.55rem 1.35rem;
	border-radius: 9999px;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background 0.15s, color 0.15s, box-shadow 0.15s, transform 0.12s;
	line-height: 1.35;
	font-family: inherit;
}
/* Stacked default / hover labels (same footprint, cross-fade on :hover) */
.aiwb-dash__btn-label-wrap {
	display: inline-grid;
	grid-template-areas: 'stack';
	align-items: center;
	justify-items: center;
	min-height: 1.25em;
	min-width: 0;
}
.aiwb-dash__btn-label-wrap > span {
	grid-area: stack;
	transition: opacity 0.2s ease;
	white-space: nowrap;
	max-width: min(100%, 18rem);
	overflow: hidden;
	text-overflow: ellipsis;
}
.aiwb-dash__btn-label--default {
	opacity: 1;
}
.aiwb-dash__btn-label--hover {
	opacity: 0;
	font-weight: 700;
}
.aiwb-dash__btn:hover .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--default,
.aiwb-dash__btn:focus-visible .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--default {
	opacity: 0;
}
.aiwb-dash__btn:hover .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--hover,
.aiwb-dash__btn:focus-visible .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--hover {
	opacity: 1;
}
.aiwb-dash__btn:disabled .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--default {
	opacity: 1;
}
.aiwb-dash__btn:disabled .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--hover {
	opacity: 0;
}
.aiwb-dash__btn--primary {
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	color: #fff;
	border-color: transparent;
	box-shadow: 0 2px 10px rgba(99,102,241,0.35);
}
.aiwb-dash__btn--primary:hover {
	background: linear-gradient(135deg, #4f46e5, #7c3aed);
	border-color: transparent;
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(99,102,241,0.45);
	color: #fff;
}
.aiwb-dash__btn--outline {
	background: var(--d-surface);
	color: var(--d-primary);
	border-color: var(--d-primary);
	box-shadow: 0 1px 4px rgba(99,102,241,0.12);
}
.aiwb-dash__btn--outline:hover {
	border-color: var(--d-primary-hover);
	color: #fff;
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	box-shadow: 0 2px 10px rgba(99,102,241,0.35);
}
.aiwb-dash__btn--ghost {
	background: transparent;
	color: var(--d-primary);
	border-color: transparent;
}
.aiwb-dash__btn--ghost:hover { color: var(--d-primary-hover); background: var(--d-primary-light); }
.aiwb-dash__btn--sm { padding: 0.4rem 1rem; font-size: 0.8125rem; }
.aiwb-dash__btn--lg { padding: 0.7rem 1.65rem; font-size: 0.9375rem; }

/* ── Alert banners ─────────────────────────────── */
.aiwb-dash__alert {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 1rem 1.25rem;
	border-radius: var(--d-radius-sm);
	margin-bottom: 1.25rem;
	font-size: 0.9rem;
	line-height: 1.5;
}
.aiwb-dash__alert--success {
	background: #ecfdf5;
	border: 1px solid #a7f3d0;
	color: #065f46;
}
.aiwb-dash__alert--success svg { color: #10b981; flex-shrink: 0; margin-top: 2px; }
.aiwb-dash__alert--error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
}
.aiwb-dash__alert--error svg { color: #ef4444; flex-shrink: 0; margin-top: 2px; }
.aiwb-dash__alert strong { display: block; margin-bottom: 0.15rem; }
.aiwb-dash__alert ul { margin: 0.35rem 0 0 1rem; padding: 0; }
.aiwb-dash__alert-actions { display: flex; gap: 0.5rem; margin-top: 0.65rem; flex-shrink: 0; }

/* ── Back link ─────────────────────────────────── */
.aiwb-dash__back-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.25rem;
}
.aiwb-dash__back-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--d-ink-muted);
	text-decoration: none;
}
.aiwb-dash__back-link:hover { color: var(--d-primary); }

/* ── Badge / Status ────────────────────────────── */
.aiwb-dash__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.6rem;
	height: 1.6rem;
	padding: 0 0.4rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 700;
	background: var(--d-primary-light);
	color: var(--d-primary);
}
.aiwb-dash__status {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
}
.aiwb-dash__status--draft { background: #fef3c7; color: #92400e; }
.aiwb-dash__status--active { background: #d1fae5; color: #065f46; }
.aiwb-dash__status--on_hold { background: #e0e7ff; color: #3730a3; }
.aiwb-dash__status--archived { background: #f1f5f9; color: #475569; }

/* ── Empty state ───────────────────────────────── */
.aiwb-dash__empty {
	text-align: center;
	padding: 3rem 1.5rem;
	color: var(--d-ink-muted);
	border: 2px dashed var(--d-line);
	border-radius: var(--d-radius);
	background: var(--d-surface);
}
.aiwb-dash__empty svg { margin-bottom: 0.75rem; color: #cbd5e1; }
.aiwb-dash__empty p { margin: 0; font-size: 0.95rem; }

/* ── Section header ────────────────────────────── */
.aiwb-dash__section { margin-top: 1.5rem; }
.aiwb-dash__section-header {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	margin-bottom: 1rem;
}
.aiwb-dash__section-header h3 {
	margin: 0;
	font-size: 1.15rem;
	font-weight: 700;
	letter-spacing: -0.02em;
}

/* ── Hero CTA card ─────────────────────────────── */
.aiwb-dash__hero-cta {
	display: flex;
	align-items: center;
	gap: clamp(1.5rem, 4vw, 3rem);
	padding: clamp(1.5rem, 3vw, 2.5rem);
	background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 50%, #c7d2fe 100%);
	border-radius: calc(var(--d-radius) + 4px);
	border: 1px solid #c7d2fe;
	overflow: hidden;
}
.aiwb-dash__hero-cta-content { flex: 1; min-width: 0; }
.aiwb-dash__hero-cta-content h2 {
	margin: 0 0 0.5rem;
	font-size: clamp(1.25rem, 2.8vw, 1.65rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	color: #312e81;
}
.aiwb-dash__hero-cta-content p {
	margin: 0 0 1.25rem;
	color: #4338ca;
	font-size: 0.95rem;
	line-height: 1.55;
	max-width: 36rem;
}
.aiwb-dash__hero-cta-visual {
	flex-shrink: 0;
	width: clamp(100px, 15vw, 160px);
}
.aiwb-dash__hero-illustration { width: 100%; height: auto; display: block; }

/* ── Project cards grid ────────────────────────── */
.aiwb-dash__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
	gap: 1rem;
}
.aiwb-dash__card {
	background: var(--d-surface);
	border: 1px solid var(--d-line);
	border-left: 3px solid #8b5cf6;
	border-radius: var(--d-radius);
	padding: 1.25rem 1.35rem;
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	transition: border-color 0.18s, box-shadow 0.18s;
}
.aiwb-dash__card:hover {
	border-color: rgba(99,102,241,0.3);
	box-shadow: var(--d-shadow);
}
.aiwb-dash__card-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0.75rem;
}
.aiwb-dash__card-title {
	margin: 0;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	word-break: break-word;
}
.aiwb-dash__card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	font-size: 0.8125rem;
	color: var(--d-ink-muted);
}
.aiwb-dash__card-meta span { display: inline-flex; align-items: center; gap: 0.3rem; }
.aiwb-dash__card-meta svg { color: #94a3b8; }
.aiwb-dash__card-actions { display: flex; gap: 0.5rem; margin-top: auto; }

/* ── Create wizard ─────────────────────────────── */
.aiwb-wizard {
	max-width: 780px;
	margin: 0 auto;
	background: var(--d-surface);
	border: 1px solid var(--d-line);
	border-radius: calc(var(--d-radius) + 4px);
	box-shadow: var(--d-shadow-lg);
	overflow: hidden;
}
.aiwb-wizard__header {
	padding: 2.25rem 2rem 1.25rem;
	text-align: center;
}
.aiwb-wizard__header h2 {
	margin: 0 0 0.4rem;
	font-size: 1.5rem;
	font-weight: 800;
	letter-spacing: -0.03em;
}
.aiwb-wizard__header p { margin: 0; color: var(--d-ink-muted); font-size: 0.925rem; line-height: 1.55; }

/* Progress indicators */
.aiwb-wizard__progress {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	padding: 0 1.5rem 1.75rem;
}
.aiwb-wizard__step-indicator {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.35rem 0.5rem;
	flex-shrink: 0;
}
.aiwb-wizard__step-num {
	width: 34px; height: 34px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.8rem;
	font-weight: 700;
	background: #f1f5f9;
	color: var(--d-ink-muted);
	border: 2px solid var(--d-line);
	transition: background 0.2s, color 0.2s, border-color 0.2s, transform 0.2s;
}
.aiwb-wizard__step-indicator:hover .aiwb-wizard__step-num { transform: scale(1.08); }
.aiwb-wizard__step-label {
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--d-ink-muted);
	transition: color 0.2s;
}
.aiwb-wizard__step-indicator.is-active .aiwb-wizard__step-num {
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	color: #fff;
	border-color: transparent;
	box-shadow: 0 2px 10px rgba(99,102,241,0.4);
	transform: scale(1.05);
}
.aiwb-wizard__step-indicator.is-active .aiwb-wizard__step-label { color: var(--d-primary); font-weight: 700; }
.aiwb-wizard__step-indicator.is-done .aiwb-wizard__step-num {
	background: linear-gradient(135deg, #10b981, #34d399);
	color: #fff;
	border-color: transparent;
	box-shadow: 0 2px 6px rgba(16,185,129,0.3);
}
.aiwb-wizard__step-indicator.is-done .aiwb-wizard__step-label { color: #059669; }
.aiwb-wizard__step-line {
	flex: 1;
	height: 2px;
	background: var(--d-line);
	min-width: 16px;
	max-width: 48px;
	margin-bottom: 1.25rem;
	transition: background 0.3s;
}
.aiwb-wizard__step-indicator.is-done + .aiwb-wizard__step-line {
	background: linear-gradient(90deg, #10b981, #6366f1);
}

/* Section header (per-step intro with icon) */
.aiwb-wizard__section-header {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	margin-bottom: 1.75rem;
	padding: 1.15rem 1.25rem;
	background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
	border-radius: var(--d-radius-sm);
	border: 1px solid #c7d2fe;
}
.aiwb-wizard__section-icon {
	flex-shrink: 0;
	width: 44px; height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--d-surface);
	border-radius: 12px;
	box-shadow: 0 1px 3px rgba(99,102,241,0.12);
	color: var(--d-primary);
}
.aiwb-wizard__section-title {
	margin: 0 0 0.2rem;
	font-size: 1.1rem;
	font-weight: 700;
	color: #312e81;
	letter-spacing: -0.01em;
}
.aiwb-wizard__section-desc {
	margin: 0;
	font-size: 0.85rem;
	color: #4338ca;
	line-height: 1.5;
}

/* Fields grid — single column (stable across browsers / themes) */
.aiwb-wizard__fields-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0 1.5rem;
}

/* Panels */
.aiwb-wizard__panel { display: none; padding: 0 2rem 0.5rem; }
.aiwb-wizard__panel.is-active { display: block; animation: aiwbFadeIn 0.25s ease; }

@keyframes aiwbFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

.aiwb-wizard__field {
	margin-bottom: 1.15rem;
}
.aiwb-wizard__field label {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--d-ink);
}
.aiwb-wizard__req { color: #ef4444; margin-left: 2px; }
.aiwb-wizard__help {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.78rem;
	color: var(--d-ink-muted);
	line-height: 1.45;
}
.aiwb-wizard__input {
	display: block;
	width: 100%;
	padding: 0.6rem 0.85rem;
	border: 1.5px solid var(--d-line);
	border-radius: var(--d-radius-sm);
	font-size: 0.9rem;
	color: var(--d-ink);
	background: var(--d-surface);
	transition: border-color 0.15s, box-shadow 0.15s;
	font-family: inherit;
	line-height: 1.5;
}
.aiwb-wizard__input:focus {
	outline: none;
	border-color: var(--d-primary);
	box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}
.aiwb-wizard__input--error {
	border-color: #ef4444 !important;
	box-shadow: 0 0 0 3px rgba(239,68,68,0.12) !important;
}
textarea.aiwb-wizard__input { resize: vertical; min-height: 68px; }
select.aiwb-wizard__input { cursor: pointer; }

/* Review step */
.aiwb-wizard__review {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.85rem;
	margin-bottom: 1.25rem;
}
.aiwb-wizard__review-card {
	padding: 1.15rem 1rem;
	background: #f8fafc;
	border: 1px solid var(--d-line);
	border-radius: var(--d-radius-sm);
	text-align: center;
	transition: border-color 0.15s, box-shadow 0.15s;
}
.aiwb-wizard__review-card:hover {
	border-color: rgba(99,102,241,0.3);
	box-shadow: 0 2px 8px rgba(99,102,241,0.08);
}
.aiwb-wizard__review-card-icon {
	width: 48px; height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 0.65rem;
	background: var(--d-primary-light);
	border-radius: 12px;
}
.aiwb-wizard__review-card h5 {
	margin: 0 0 0.25rem;
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--d-ink);
}
.aiwb-wizard__review-card p {
	margin: 0;
	font-size: 0.78rem;
	color: var(--d-ink-muted);
	line-height: 1.4;
}
.aiwb-wizard__review-note {
	margin: 0;
	padding: 0.85rem 1rem;
	background: #fffbeb;
	border: 1px solid #fde68a;
	border-radius: var(--d-radius-sm);
	font-size: 0.83rem;
	color: #92400e;
	line-height: 1.5;
	text-align: center;
}

/* ── AI Suggest panel ──────────────────────────── */
.aiwb-ai-suggest {
	margin-top: 1.5rem;
	padding-top: 1.5rem;
	border-top: 1px dashed var(--d-line);
}
.aiwb-ai-suggest__inner {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.25rem;
	border-radius: var(--d-radius-sm);
	background: linear-gradient(135deg, rgba(99,102,241,0.06) 0%, rgba(139,92,246,0.06) 100%);
	border: 1px solid rgba(99,102,241,0.15);
}
.aiwb-ai-suggest__info {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	flex: 1;
	min-width: 0;
}
.aiwb-ai-suggest__icon {
	flex-shrink: 0;
	width: 36px; height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	color: #fff;
}
.aiwb-ai-suggest__text {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	font-size: 0.85rem;
	line-height: 1.45;
}
.aiwb-ai-suggest__text strong {
	font-size: 0.9rem;
	color: var(--d-ink);
}
.aiwb-ai-suggest__text span {
	color: var(--d-ink-muted);
}
.aiwb-ai-suggest__btn {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.6rem 1.4rem;
	border: none;
	border-radius: 9999px;
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	color: #fff;
	font-size: 0.85rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	box-shadow: 0 2px 10px rgba(99,102,241,0.35);
	transition: transform 0.15s, box-shadow 0.15s, opacity 0.15s, background 0.15s, color 0.15s;
	white-space: nowrap;
}
.aiwb-ai-suggest__btn:hover:not(:disabled) {
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(99,102,241,0.45);
	background: linear-gradient(135deg, #4f46e5, #7c3aed);
	color: #fff;
}
.aiwb-ai-suggest__btn:hover:not(:disabled) .aiwb-ai-suggest__btn-icon,
.aiwb-ai-suggest__btn:hover:not(:disabled) .aiwb-ai-suggest__btn-spinner,
.aiwb-ai-suggest__btn:hover:not(:disabled) .aiwb-ai-suggest__btn-text,
.aiwb-ai-suggest__btn:hover:not(:disabled) .aiwb-ai-suggest__btn-text-loading {
	color: #fff;
}
.aiwb-ai-suggest__btn:hover:not(:disabled):not(.is-loading) .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--default,
.aiwb-ai-suggest__btn:focus-visible:not(:disabled):not(.is-loading) .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--default {
	opacity: 0;
}
.aiwb-ai-suggest__btn:hover:not(:disabled):not(.is-loading) .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--hover,
.aiwb-ai-suggest__btn:focus-visible:not(:disabled):not(.is-loading) .aiwb-dash__btn-label-wrap .aiwb-dash__btn-label--hover {
	opacity: 1;
}
.aiwb-ai-suggest__btn:disabled {
	opacity: 0.7;
	cursor: wait;
}
.aiwb-ai-suggest__btn-spinner { display: none; }
.aiwb-ai-suggest__btn-text-loading { display: none; }
.aiwb-ai-suggest__btn.is-loading .aiwb-ai-suggest__btn-icon { display: none; }
.aiwb-ai-suggest__btn.is-loading .aiwb-ai-suggest__btn-spinner { display: inline-block; }
.aiwb-ai-suggest__btn.is-loading .aiwb-ai-suggest__btn-text { display: none; }
.aiwb-ai-suggest__btn.is-loading .aiwb-ai-suggest__btn-text-loading { display: inline; }

.aiwb-ai-suggest__status {
	margin-top: 0.65rem;
	font-size: 0.82rem;
	line-height: 1.45;
	min-height: 1.2em;
	padding: 0 0.25rem;
}
.aiwb-ai-suggest__status:empty { display: none; }
.aiwb-ai-suggest__status--loading { color: var(--d-primary); }
.aiwb-ai-suggest__status--success { color: #059669; font-weight: 600; }
.aiwb-ai-suggest__status--error { color: #dc2626; }

@keyframes aiwbAiFill {
	0%   { background-color: rgba(99,102,241,0.15); box-shadow: 0 0 0 3px rgba(99,102,241,0.2); }
	100% { background-color: transparent; box-shadow: 0 0 0 0 transparent; }
}
.aiwb-wizard__input--ai-filled {
	animation: aiwbAiFill 1.5s ease-out forwards;
	border-color: #8b5cf6 !important;
}

@media (max-width: 768px) {
	.aiwb-ai-suggest__inner {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}
	.aiwb-ai-suggest__info {
		flex-direction: column;
		align-items: center;
	}
	.aiwb-ai-suggest__btn {
		justify-content: center;
	}
}

/* Wizard nav */
.aiwb-wizard__nav {
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
	padding: 1.5rem 2rem 2rem;
}

/* ── Create success ────────────────────────────── */
.aiwb-dash__view--create-success { display: flex; justify-content: center; padding: 3rem 1rem; }
.aiwb-dash__success-card {
	text-align: center;
	max-width: 480px;
	background: var(--d-surface);
	border-radius: calc(var(--d-radius) + 4px);
	padding: 3rem 2.5rem;
	box-shadow: var(--d-shadow-lg);
	border: 1px solid var(--d-line);
}
.aiwb-dash__success-icon { margin-bottom: 1rem; }
.aiwb-dash__success-card h2 { margin: 0 0 0.5rem; font-size: 1.5rem; font-weight: 800; color: #059669; }
.aiwb-dash__success-name {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--d-ink);
	margin: 0 0 0.75rem;
}
.aiwb-dash__success-card > p { color: var(--d-ink-muted); line-height: 1.55; margin: 0 0 1.5rem; }
.aiwb-dash__success-actions {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	align-items: center;
}

/* ── Preview view ──────────────────────────────── */
.aiwb-dash .aiwb-preview {
	background: var(--d-surface);
	border: 1px solid var(--d-line);
	border-radius: calc(var(--d-radius) + 4px);
	overflow: hidden;
	box-shadow: var(--d-shadow);
}
.aiwb-dash .aiwb-preview__toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.85rem 1.5rem;
	border-bottom: 1px solid var(--d-line);
	flex-wrap: wrap;
}
.aiwb-dash .aiwb-preview__toolbar h3 { margin: 0; font-size: 1.05rem; font-weight: 700; }
.aiwb-dash .aiwb-preview__toolbar-right {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.aiwb-dash .aiwb-preview__tabs { display: flex; gap: 0.25rem; }
.aiwb-dash .aiwb-preview__tab {
	padding: 0.4rem 0.85rem;
	border-radius: 12px;
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	color: var(--d-ink-muted);
	transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}
/* Explicit contrast so theme link:hover rules cannot wash out label on hover */
.aiwb-dash .aiwb-preview__tab:hover {
	background: #e0e7ff;
	color: #312e81;
	box-shadow: inset 0 0 0 1px rgba(99, 102, 241, 0.22);
}
.aiwb-dash .aiwb-preview__tab.is-active {
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	color: #fff;
	box-shadow: 0 2px 6px rgba(99,102,241,0.3);
}
.aiwb-dash .aiwb-preview__tab.is-active:hover {
	background: linear-gradient(135deg, #4f46e5, #7c3aed);
	color: #fff;
	box-shadow: 0 2px 10px rgba(99,102,241,0.4);
}

/* Responsive device toggle (desktop / tablet / mobile — screen preview) */
.aiwb-preview__responsive-toggle {
	display: flex;
	gap: 3px;
	background: var(--d-bg);
	border-radius: 14px;
	padding: 4px;
	border: 1px solid var(--d-line);
}
.aiwb-preview__device {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: none;
	border-radius: 11px;
	background: transparent;
	color: #475569;
	cursor: pointer;
	transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}
.aiwb-preview__device svg {
	flex-shrink: 0;
	color: inherit;
}
/* Strong contrast on hover so icon stroke (currentColor) never matches the surface */
.aiwb-preview__device:hover {
	background: #e0e7ff;
	color: #312e81;
	box-shadow: inset 0 0 0 1px rgba(99, 102, 241, 0.25);
}
.aiwb-preview__device.is-active {
	background: linear-gradient(135deg, #6366f1, #8b5cf6);
	color: #fff;
	box-shadow: 0 1px 4px rgba(99,102,241,0.3);
}
.aiwb-preview__device.is-active:hover {
	background: linear-gradient(135deg, #4f46e5, #7c3aed);
	color: #fff;
	box-shadow: 0 2px 8px rgba(99,102,241,0.38);
}

/* Viewport container for responsive preview */
.aiwb-preview__viewport {
	background: var(--d-bg);
	transition: padding 0.3s ease;
	overflow: auto;
}
.aiwb-preview__viewport[data-device="desktop"] {
	padding: 0;
}
.aiwb-preview__viewport[data-device="tablet"] {
	padding: 1.5rem;
}
.aiwb-preview__viewport[data-device="mobile"] {
	padding: 1.5rem;
}
.aiwb-preview__viewport[data-device="tablet"] .aiwb-preview__frame,
.aiwb-preview__viewport[data-device="mobile"] .aiwb-preview__frame {
	margin: 0 auto;
	border-radius: 12px;
	border: 2px solid var(--d-line);
	box-shadow: 0 4px 24px rgba(15,23,42,0.12);
	background: var(--d-surface);
	overflow: hidden;
	transition: max-width 0.35s ease, box-shadow 0.3s ease;
}
.aiwb-preview__viewport[data-device="tablet"] .aiwb-preview__frame {
	max-width: 768px;
}
.aiwb-preview__viewport[data-device="mobile"] .aiwb-preview__frame {
	max-width: 375px;
}
.aiwb-preview__viewport[data-device="tablet"] .aiwb-preview__frame::before,
.aiwb-preview__viewport[data-device="mobile"] .aiwb-preview__frame::before {
	content: '';
	display: block;
	height: 28px;
	background: linear-gradient(180deg, #f1f5f9 0%, #e8ecf1 100%);
	border-bottom: 1px solid var(--d-line);
	border-radius: 12px 12px 0 0;
	position: relative;
}
.aiwb-preview__viewport[data-device="tablet"] .aiwb-preview__frame::after,
.aiwb-preview__viewport[data-device="mobile"] .aiwb-preview__frame::after {
	content: '';
	position: absolute;
	top: 12px;
	left: 50%;
	transform: translateX(-50%);
	width: 48px; height: 5px;
	border-radius: 999px;
	background: #cbd5e1;
}
.aiwb-preview__viewport[data-device="tablet"] .aiwb-preview__frame,
.aiwb-preview__viewport[data-device="mobile"] .aiwb-preview__frame {
	position: relative;
}

.aiwb-dash .aiwb-preview__frame { min-height: 400px; }
.aiwb-dash .aiwb-preview__empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 300px;
	padding: 2.5rem 2rem;
	color: var(--d-ink-muted);
	text-align: center;
	gap: 0.75rem;
}
.aiwb-dash .aiwb-preview__empty svg { color: #cbd5e1; }
.aiwb-dash .aiwb-preview__empty p { margin: 0; font-size: 0.95rem; }
.aiwb-dash .aiwb-preview__empty-sub { font-size: 0.85rem; color: #94a3b8; max-width: 28rem; }
.aiwb-dash .aiwb-preview__empty .aiwb-fe-ai-panel {
	margin-top: 0.5rem;
	padding: 1rem 1.5rem;
	border-radius: var(--d-radius-sm);
	text-align: center;
	background: #f8fafc;
	border: 1px solid var(--d-line);
	max-width: 400px;
}
/* Style AI / legacy submit buttons in dashboard (not .aiwb-dash__btn — wizard submit keeps .aiwb-dash__btn styles) */
.aiwb-dash .aiwb-hf-button,
.aiwb-dash .aiwb-pf-button,
.aiwb-dash button[type="submit"]:not(.aiwb-dash__btn) {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 1.4rem;
	border-radius: var(--d-radius-sm);
	font-size: 0.9rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	text-decoration: none;
	border: none;
	background: linear-gradient(135deg, var(--d-primary), #8b5cf6);
	color: #fff;
	box-shadow: 0 2px 10px rgba(99,102,241,0.35);
	transition: transform 0.15s, box-shadow 0.15s, opacity 0.15s;
	line-height: 1.4;
}
.aiwb-dash .aiwb-hf-button:hover,
.aiwb-dash .aiwb-pf-button:hover,
.aiwb-dash button[type="submit"]:not(.aiwb-dash__btn):hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(99,102,241,0.45);
	color: #fff;
	opacity: 0.95;
}

.aiwb-dash .aiwb-preview__empty .aiwb-fe-ai-panel__title { font-size: 0.95rem; }
.aiwb-dash .aiwb-preview__rendered { padding: 0; overflow: hidden; }
.aiwb-preview__viewport:not([data-device]),
.aiwb-preview__viewport[data-device="desktop"] { background: var(--d-surface); }
.aiwb-dash .aiwb-preview__regenerate {
	margin-top: 1.25rem;
}
.aiwb-dash .aiwb-fe-ai-panel {
	padding: 1.15rem 1.5rem;
	border-radius: var(--d-radius-sm);
	background: var(--d-surface);
	border: 1px solid var(--d-line);
	box-shadow: var(--d-shadow);
}
.aiwb-dash .aiwb-fe-ai-panel__title {
	font-size: 1rem;
	margin-bottom: 0.5rem;
	color: var(--d-ink);
}
.aiwb-dash .aiwb-fe-ai-panel .aiwb-hf-help {
	color: var(--d-ink-muted);
	font-size: 0.85rem;
}
.aiwb-dash .aiwb-preview__empty {
	flex-direction: column;
}
.aiwb-dash .aiwb-preview__empty .aiwb-fe-ai-panel {
	margin-top: 0.5rem;
	max-width: 420px;
	text-align: center;
}

/* ── Export view ───────────────────────────────── */
.aiwb-export__header { margin-bottom: 1.5rem; }
.aiwb-export__header h2 { margin: 0 0 0.35rem; font-size: 1.35rem; font-weight: 800; letter-spacing: -0.02em; }
.aiwb-export__header p { margin: 0; color: var(--d-ink-muted); font-size: 0.95rem; }
.aiwb-export__page-group { margin-bottom: 1.5rem; }
.aiwb-export__page-group h3 {
	margin: 0 0 0.75rem;
	font-size: 1rem;
	font-weight: 700;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--d-line);
}
.aiwb-export__formats {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 200px), 1fr));
	gap: 0.75rem;
}
.aiwb-export__format-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	padding: 1.25rem 1rem;
	background: var(--d-surface);
	border: 1px solid var(--d-line);
	border-radius: var(--d-radius);
	text-decoration: none;
	color: var(--d-ink);
	text-align: center;
	transition: border-color 0.18s, box-shadow 0.18s, transform 0.12s;
}
.aiwb-export__format-card:hover {
	border-color: var(--d-primary);
	box-shadow: 0 4px 16px rgba(99,102,241,0.2);
	transform: translateY(-2px);
	color: var(--d-ink);
	background: var(--d-primary-light);
}
.aiwb-export__format-icon { color: #8b5cf6; }
.aiwb-export__format-name { font-size: 0.9rem; font-weight: 700; }
.aiwb-export__format-desc { font-size: 0.75rem; color: var(--d-ink-muted); line-height: 1.4; }

/* ── Focus ring ────────────────────────────────── */
.aiwb-dash :is(a, button, input, textarea, select):focus-visible {
	outline: 2px solid var(--d-primary);
	outline-offset: 2px;
}

/* ── Responsive ────────────────────────────────── */
@media (max-width: 768px) {
	.aiwb-dash__topbar-inner {
		flex-wrap: wrap;
		height: auto;
		padding-top: 0.65rem;
		padding-bottom: 0.65rem;
	}
	.aiwb-dash__topnav { margin-left: 0; order: 3; width: 100%; gap: 0.15rem; }
	.aiwb-dash__topbar-right { margin-left: auto; }
	.aiwb-dash__username { display: none; }
	.aiwb-dash__hero-cta { flex-direction: column; text-align: center; }
	.aiwb-dash__hero-cta-visual { width: 120px; order: -1; }
	.aiwb-wizard__header,
	.aiwb-wizard__panel,
	.aiwb-wizard__nav { padding-left: 1.25rem; padding-right: 1.25rem; }
	.aiwb-wizard__progress { padding-left: 0.75rem; padding-right: 0.75rem; }
	.aiwb-wizard__step-indicator { padding: 0.25rem 0.35rem; }
	.aiwb-wizard__section-header { flex-direction: column; align-items: flex-start; gap: 0.65rem; }
	.aiwb-wizard__review { grid-template-columns: 1fr 1fr; }
	.aiwb-dash__success-card { padding: 2rem 1.5rem; }
}

@media (max-width: 480px) {
	.aiwb-dash__grid { grid-template-columns: 1fr; }
	.aiwb-export__formats { grid-template-columns: 1fr; }
	.aiwb-dash .aiwb-preview__toolbar { flex-direction: column; align-items: flex-start; }
	.aiwb-dash .aiwb-preview__toolbar-right { flex-direction: column; align-items: flex-start; width: 100%; }
	.aiwb-preview__responsive-toggle { display: none; }
	.aiwb-wizard__step-label { display: none; }
	.aiwb-wizard__step-line { min-width: 10px; max-width: 28px; }
	.aiwb-wizard__review { grid-template-columns: 1fr; }
	.aiwb-wizard__section-header { padding: 0.85rem 1rem; }
}

/* [aiwb_project_form] */
.aiwb-project-form {
	max-width: 720px;
	margin: 0 auto 2rem;
	padding: 1.25rem 1.5rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: var(--aiwb-fe-radius);
	background: var(--aiwb-fe-surface);
	box-shadow: var(--aiwb-fe-shadow);
	box-sizing: border-box;
}

.aiwb-project-form--login-required,
.aiwb-project-form--no-access {
	max-width: 32rem;
}

.aiwb-pf-alert {
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	border-radius: 4px;
}

.aiwb-pf-alert--success {
	border: 1px solid #00a32a;
	background: #edfaef;
	color: #1e4620;
}

.aiwb-pf-alert--error {
	border: 1px solid #d63638;
	background: #fcf0f1;
	color: #3c1f1f;
}

.aiwb-pf-message {
	margin: 0 0 0.5rem;
	line-height: 1.5;
}

.aiwb-pf-error-list {
	margin: 0.25rem 0 0 1.25rem;
	padding: 0;
}

.aiwb-pf-fieldset {
	margin: 0 0 1.25rem;
	padding: 0;
	border: none;
}

.aiwb-pf-legend {
	padding: 0;
	margin: 0 0 0.75rem;
	font-size: 1.05rem;
	font-weight: 600;
}

.aiwb-pf-row {
	margin-bottom: 1rem;
}

.aiwb-pf-label {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	font-weight: 500;
}

.aiwb-pf-label__text {
	font-weight: 600;
}

.aiwb-pf-required {
	text-decoration: none;
	border: none;
}

.aiwb-pf-control {
	width: 100%;
	max-width: 100%;
	padding: 0.5rem 0.65rem;
	border: 1px solid rgba(0, 0, 0, 0.15);
	border-radius: 4px;
	font: inherit;
	box-sizing: border-box;
}

.aiwb-pf-control--textarea {
	min-height: 6rem;
	resize: vertical;
}

.aiwb-pf-help {
	font-size: 0.85rem;
	font-weight: 400;
	color: #555;
}

.aiwb-pf-actions {
	margin-top: 1.25rem;
}

.aiwb-pf-button {
	display: inline-block;
	padding: 0.55rem 1.1rem;
	border-radius: 8px;
	text-decoration: none;
	font-weight: 600;
	border: 1px solid var(--aiwb-fe-accent);
	background: #f6f7f7;
	color: var(--aiwb-fe-accent);
	cursor: pointer;
	font: inherit;
}

.aiwb-pf-button--primary {
	background: var(--aiwb-fe-accent);
	color: #fff;
	border-color: var(--aiwb-fe-accent);
}

.aiwb-pf-button--primary:hover,
.aiwb-pf-button--primary:focus-visible {
	background: var(--aiwb-fe-accent-hover);
	border-color: var(--aiwb-fe-accent-hover);
	color: #fff;
}

.aiwb-project-form :is(input, textarea, select, button, .aiwb-pf-button):focus-visible {
	outline: 2px solid var(--aiwb-fe-focus);
	outline-offset: 2px;
}

/* [aiwb_about_form] [aiwb_contact_form] [aiwb_custom_page_form] */
.aiwb-builder-page-form {
	max-width: 760px;
	margin: 0 auto 2rem;
	padding: 1.25rem 1.5rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: var(--aiwb-fe-radius);
	background: var(--aiwb-fe-surface);
	box-shadow: var(--aiwb-fe-shadow);
	box-sizing: border-box;
}

.aiwb-builder-page-form--login-required,
.aiwb-builder-page-form--no-access,
.aiwb-builder-page-form--no-project,
.aiwb-builder-page-form--forbidden {
	max-width: 36rem;
}

/* [aiwb_homepage_form] */
.aiwb-homepage-form {
	max-width: 760px;
	margin: 0 auto 2rem;
	padding: 1.25rem 1.5rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: var(--aiwb-fe-radius);
	background: var(--aiwb-fe-surface);
	box-shadow: var(--aiwb-fe-shadow);
	box-sizing: border-box;
}

.aiwb-homepage-form--login-required,
.aiwb-homepage-form--no-access,
.aiwb-homepage-form--no-project,
.aiwb-homepage-form--forbidden {
	max-width: 36rem;
}

.aiwb-hf-header {
	margin-bottom: 1.25rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--aiwb-fe-border);
}

.aiwb-hf-title {
	margin: 0 0 0.35rem;
	font-size: 1.35rem;
}

.aiwb-hf-subtitle,
.aiwb-hf-meta {
	margin: 0.25rem 0 0;
	color: #444;
	font-size: 0.95rem;
	line-height: 1.5;
}

.aiwb-hf-meta {
	font-size: 0.85rem;
	color: #666;
}

.aiwb-hf-alert {
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	border-radius: 4px;
}

.aiwb-hf-alert--success {
	border: 1px solid #00a32a;
	background: #edfaef;
	color: #1e4620;
}

.aiwb-hf-alert--error {
	border: 1px solid #d63638;
	background: #fcf0f1;
	color: #3c1f1f;
}

.aiwb-hf-message {
	margin: 0 0 0.35rem;
	line-height: 1.5;
}

.aiwb-hf-error-list {
	margin: 0.25rem 0 0 1.25rem;
	padding: 0;
}

.aiwb-hf-section {
	margin-bottom: 1.5rem;
}

.aiwb-hf-section-title {
	margin: 0 0 0.75rem;
	font-size: 1.1rem;
}

.aiwb-hf-section-body {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.aiwb-hf-field {
	margin: 0;
}

.aiwb-hf-label {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	font-weight: 500;
}

.aiwb-hf-label__text {
	font-weight: 600;
}

.aiwb-hf-required {
	text-decoration: none;
	border: none;
}

.aiwb-hf-control {
	width: 100%;
	max-width: 100%;
	padding: 0.5rem 0.65rem;
	border: 1px solid rgba(0, 0, 0, 0.15);
	border-radius: 4px;
	font: inherit;
	box-sizing: border-box;
}

.aiwb-hf-control--textarea {
	min-height: 5rem;
	resize: vertical;
}

.aiwb-hf-control--select {
	cursor: pointer;
}

.aiwb-hf-help {
	font-size: 0.85rem;
	font-weight: 400;
	color: #555;
}

.aiwb-hf-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 1rem 1.25rem;
	margin-top: 0.5rem;
}

.aiwb-hf-ai-slot {
	margin-top: 1.25rem;
}

.aiwb-hf-button {
	display: inline-block;
	padding: 0.55rem 1.1rem;
	border-radius: 8px;
	text-decoration: none;
	font-weight: 600;
	border: 1px solid var(--aiwb-fe-accent);
	background: #f6f7f7;
	color: var(--aiwb-fe-accent);
	cursor: pointer;
	font: inherit;
}

.aiwb-hf-button--primary {
	background: var(--aiwb-fe-accent);
	color: #fff;
	border-color: var(--aiwb-fe-accent);
}

.aiwb-hf-button--primary:hover,
.aiwb-hf-button--primary:focus-visible {
	background: var(--aiwb-fe-accent-hover);
	border-color: var(--aiwb-fe-accent-hover);
	color: #fff;
}

.aiwb-hf-button:hover,
.aiwb-hf-button:focus-visible {
	border-color: rgba(29, 107, 175, 0.45);
}

.aiwb-homepage-form :is(input, textarea, select, button, .aiwb-hf-button):focus-visible,
.aiwb-builder-page-form :is(input, textarea, select, button, .aiwb-hf-button):focus-visible {
	outline: 2px solid var(--aiwb-fe-focus);
	outline-offset: 2px;
}

.aiwb-hf-footer-link {
	margin: 1rem 0 0;
	font-size: 0.9rem;
}

.aiwb-hf-link {
	color: var(--aiwb-fe-accent);
}

/* Front AI generate panel (separate form from draft save) */
.aiwb-fe-ai-panel {
	margin-top: 1.5rem;
	padding: 1.1rem 1.15rem 1.15rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: calc(var(--aiwb-fe-radius) - 2px);
	background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
	box-sizing: border-box;
}

.aiwb-fe-ai-panel__title {
	margin: 0 0 0.65rem;
	font-size: clamp(1rem, 2.2vw, 1.1rem);
	font-weight: 700;
	color: #0f172a;
}

.aiwb-fe-ai-panel__notice {
	margin: 0 0 0.75rem;
	padding: 0.55rem 0.75rem;
	border-radius: 8px;
	background: #fffbeb;
	border: 1px solid rgba(219, 166, 23, 0.55);
	font-size: 0.9rem;
	color: #713f12;
}

.aiwb-fe-ai-panel__overwrite {
	margin: 0 0 0.75rem;
	font-size: 0.9rem;
}

.aiwb-fe-ai-panel__submit {
	margin: 0;
}

.aiwb-fe-ai-flash {
	margin-bottom: 1rem;
}

.aiwb-fe-ai-flash--error,
.aiwb-fe-wp-pub-flash--error {
	border-radius: 8px;
}

.aiwb-fe-ai-flash--success,
.aiwb-fe-wp-pub-flash--success {
	border-radius: 8px;
}

/* [aiwb_generated_preview] */
.aiwb-gen-preview {
	max-width: 960px;
	margin: 0 auto 2rem;
	padding: 1.15rem 1.35rem 1.5rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: var(--aiwb-fe-radius);
	background: var(--aiwb-fe-surface);
	box-shadow: var(--aiwb-fe-shadow);
	box-sizing: border-box;
}

.aiwb-gen-preview__header {
	margin-bottom: 1rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid var(--aiwb-fe-border);
}

.aiwb-gen-preview__title {
	margin: 0 0 0.35rem;
	font-size: clamp(1.15rem, 2.5vw, 1.35rem);
	font-weight: 700;
	color: #0f172a;
}

.aiwb-gen-preview__subtitle {
	margin: 0;
	color: var(--aiwb-fe-muted);
	font-size: 0.95rem;
}

.aiwb-gen-preview__meta {
	margin: 0 0 0.75rem;
	font-size: 0.85rem;
	color: var(--aiwb-fe-muted);
}

.aiwb-gen-preview__frame {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: 8px;
}

.aiwb-gen-preview__message {
	margin: 0;
	line-height: 1.5;
}

.aiwb-gen-preview__empty {
	margin: 1rem 0;
	padding: 1rem 1.25rem;
	border-radius: 8px;
	border: 1px dashed rgba(15, 23, 42, 0.15);
	background: #f8fafc;
}

.aiwb-gen-preview__admin-link {
	margin: 1rem 0 0;
	font-size: 0.9rem;
}

.aiwb-gen-preview__publish,
.aiwb-fe-wp-publish {
	margin-top: 1.35rem;
	padding: 1rem 1.15rem;
	border: 1px solid var(--aiwb-fe-border);
	border-radius: calc(var(--aiwb-fe-radius) - 2px);
	background: #f8fafc;
	box-sizing: border-box;
}

.aiwb-fe-wp-publish__title,
.aiwb-gen-preview__publish .aiwb-fe-wp-publish__title {
	margin: 0 0 0.5rem;
	font-size: 1.05rem;
	font-weight: 700;
	color: #0f172a;
}

.aiwb-fe-wp-publish__form {
	margin: 0;
}

.aiwb-fe-wp-publish__submit {
	margin: 0.75rem 0 0;
}

/* [aiwb_render_page] */
.aiwb-render-page {
	max-width: 960px;
	margin: 0 auto 1.5rem;
	box-sizing: border-box;
}

.aiwb-render-page__message {
	margin: 0;
	line-height: 1.5;
}

/* Responsive layout */
@media (max-width: 782px) {
	.aiwb-fe,
	.aiwb-user-dashboard,
	.aiwb-project-form,
	.aiwb-homepage-form,
	.aiwb-builder-page-form,
	.aiwb-gen-preview {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.aiwb-fe .form-table th,
	.aiwb-fe .form-table td {
		display: block;
		width: 100%;
		max-width: none;
		padding: 0.35rem 0;
	}

	.aiwb-fe .form-table th {
		padding-top: 0.85rem;
	}

	.aiwb-fe .aiwb-fe__table {
		font-size: 0.88rem;
	}

	.aiwb-fe .aiwb-project-nav__list {
		flex-direction: column;
		align-items: stretch;
	}

	.aiwb-fe .aiwb-project-nav__link {
		text-align: center;
	}

	.aiwb-hf-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.aiwb-hf-actions .aiwb-hf-button {
		text-align: center;
	}
}

@media (max-width: 480px) {
	.aiwb-fe,
	.aiwb-user-dashboard,
	.aiwb-project-form,
	.aiwb-homepage-form,
	.aiwb-builder-page-form,
	.aiwb-gen-preview {
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}

	.aiwb-ud-list--inline {
		flex-direction: column;
		align-items: flex-start;
	}
}
