:root {
	--purple: #5B2AD6;
	--turquoise: #00C2C7;
	--navy: #172B4D;
	--paper: #F6F8FC;
	--white: #FFFFFF;
	--yellow: #FFD166;
	--text: #263B5E;
	--muted: #65738B;
	--line: #DDE5F0;
	--shadow: 0 22px 60px rgba(23, 43, 77, 0.12);
	--soft-shadow: 0 16px 42px rgba(23, 43, 77, 0.08);
	--radius-sm: 16px;
	--radius-md: 20px;
	--radius-lg: 24px;
	--radius-xl: 30px;
	--radius-pill: 999px;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: "Inter", Arial, sans-serif;
	color: var(--text);
	background:
		linear-gradient(rgba(91, 42, 214, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0, 194, 199, 0.035) 1px, transparent 1px),
		var(--paper);
	background-size: 44px 44px;
	line-height: 1.6;
}

img {
	max-width: 100%;
	display: block;
}

a {
	color: inherit;
	text-decoration: none;
}

.container {
	width: min(1120px, calc(100% - 40px));
	margin: 0 auto;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 10;
	background: rgba(255, 255, 255, 0.94);
	border-bottom: 1px solid rgba(221, 229, 240, 0.8);
	backdrop-filter: blur(14px);
}

.nav-shell {
	min-height: 76px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.brand-logo {
	width: 162px;
	height: auto;
	mix-blend-mode: multiply;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 24px;
	font-size: 14px;
	font-weight: 800;
	color: var(--navy);
}

.site-nav a:hover,
.mobile-nav a:hover {
	color: var(--purple);
}

.nav-actions,
.hero-actions {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 11px 18px;
	border-radius: var(--radius-pill);
	font-weight: 800;
	font-size: 14px;
	border: 1px solid transparent;
	transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.btn:hover {
	transform: translateY(-1px);
}

.btn.is-disabled,
.btn:disabled {
	cursor: not-allowed;
	opacity: 0.56;
	transform: none;
}

.btn-primary {
	color: var(--white);
	background: linear-gradient(135deg, var(--purple), var(--turquoise));
	box-shadow: 0 12px 24px rgba(91, 42, 214, 0.24);
}

.btn-ghost {
	color: var(--navy);
	background: var(--white);
	border-color: var(--line);
}

.btn-light {
	color: var(--navy);
	background: rgba(255, 255, 255, 0.88);
	border-color: rgba(255, 255, 255, 0.72);
}

.btn-large {
	min-height: 52px;
	padding: 14px 22px;
	font-size: 15px;
}

.full {
	width: 100%;
}

.nav-toggle {
	display: none;
	width: 44px;
	height: 44px;
	border: 1px solid var(--line);
	border-radius: var(--radius-sm);
	background: var(--white);
	padding: 10px;
}

.nav-toggle span {
	display: block;
	height: 2px;
	margin: 5px 0;
	background: var(--navy);
	border-radius: 2px;
}

.mobile-nav {
	display: none;
	border-top: 1px solid var(--line);
	background: var(--white);
	padding: 10px 20px 20px;
}

.mobile-nav a {
	display: block;
	padding: 11px 0;
	font-weight: 800;
	color: var(--navy);
}

.hero {
	position: relative;
	overflow: hidden;
	padding: 96px 0 76px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94) 0%, rgba(246, 248, 252, 0.84) 54%, rgba(238, 250, 251, 0.92) 100%);
}

.hero:before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(120deg, rgba(91, 42, 214, 0.08), rgba(0, 194, 199, 0.06)),
		linear-gradient(rgba(23, 43, 77, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(23, 43, 77, 0.035) 1px, transparent 1px);
	background-size: auto, 72px 72px, 72px 72px;
	pointer-events: none;
}

.hero-grid {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 0.92fr;
	gap: 70px;
	align-items: center;
}

.eyebrow,
.mini-label {
	margin: 0 0 12px;
	color: var(--purple);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 0;
}

h1,
h2,
h3 {
	margin: 0;
	font-family: "Poppins", Arial, sans-serif;
	color: var(--navy);
	line-height: 1.12;
}

h1 {
	font-size: clamp(43px, 6vw, 72px);
	max-width: 720px;
}

h2 {
	font-size: clamp(30px, 4vw, 46px);
}

h3 {
	font-size: 20px;
}

p {
	margin: 0;
}

.hero-subtitle {
	max-width: 620px;
	margin: 24px 0 28px;
	font-size: 19px;
	color: var(--text);
}

.hero-note {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 24px;
}

.hero-note span,
.credit-badge,
.plan-badge {
	display: inline-flex;
	align-items: center;
	border-radius: var(--radius-pill);
	background: rgba(255, 209, 102, 0.24);
	color: #6F5200;
	padding: 8px 12px;
	font-size: 13px;
	font-weight: 800;
}

.hero-note span:first-child {
	background: rgba(91, 42, 214, 0.1);
	color: var(--purple);
}

.ai-hero-panel {
	position: relative;
	display: grid;
	gap: 14px;
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(221, 229, 240, 0.86);
	border-radius: var(--radius-xl);
	box-shadow: var(--soft-shadow);
	padding: 18px;
	overflow: hidden;
}

.ai-hero-panel:before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(91, 42, 214, 0.06), rgba(0, 194, 199, 0.07)),
		linear-gradient(90deg, transparent 0, transparent 96%, rgba(0, 194, 199, 0.18) 100%);
	pointer-events: none;
}

.ai-mark,
.ai-network,
.product-card,
.selector-grid,
.ai-output {
	position: relative;
	z-index: 1;
}

.ai-mark {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 116px;
	height: 116px;
	margin: 4px auto 0;
	border-radius: var(--radius-lg);
	background: var(--white);
	border: 1px solid var(--line);
	box-shadow: 0 14px 30px rgba(23, 43, 77, 0.07);
}

.ai-mark img {
	width: 86px;
	height: 86px;
	object-fit: contain;
	mix-blend-mode: multiply;
}

.ai-network {
	min-height: 78px;
	border-radius: var(--radius-lg);
	background:
		linear-gradient(90deg, transparent 0 16%, rgba(91, 42, 214, 0.26) 16% 17%, transparent 17% 39%, rgba(0, 194, 199, 0.24) 39% 40%, transparent 40% 68%, rgba(91, 42, 214, 0.20) 68% 69%, transparent 69%),
		linear-gradient(180deg, transparent 0 49%, rgba(23, 43, 77, 0.1) 49% 51%, transparent 51%);
}

.ai-network span {
	position: absolute;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--purple), var(--turquoise));
	box-shadow: 0 0 0 8px rgba(0, 194, 199, 0.07);
}

.ai-network span:nth-child(1) { left: 8%; top: 42%; }
.ai-network span:nth-child(2) { left: 22%; top: 18%; }
.ai-network span:nth-child(3) { left: 38%; top: 52%; }
.ai-network span:nth-child(4) { left: 57%; top: 24%; }
.ai-network span:nth-child(5) { left: 74%; top: 48%; }
.ai-network span:nth-child(6) { left: 89%; top: 22%; }

.product-card {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	align-items: start;
	padding: 20px;
	border-radius: var(--radius-lg);
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(91, 42, 214, 0.12);
}

.product-card h2 {
	font-size: 25px;
}

.selector-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	margin-top: 14px;
}

.selector-grid div {
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 15px;
}

.selector-grid span {
	display: block;
	color: var(--muted);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
}

.selector-grid strong {
	display: block;
	margin-top: 3px;
	color: var(--navy);
	font-size: 14px;
}

.ai-output {
	margin-top: 14px;
	display: grid;
	gap: 10px;
}

.output-row {
	display: grid;
	grid-template-columns: 12px 1fr auto;
	align-items: center;
	gap: 10px;
	padding: 13px 14px;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
}

.output-row span {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--turquoise);
	box-shadow: 0 0 0 5px rgba(0, 194, 199, 0.12);
}

.output-row strong {
	color: var(--navy);
}

.output-row em {
	font-style: normal;
	color: var(--purple);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.section {
	padding: 82px 0;
}

.trust-band {
	padding: 30px 0;
	background: var(--white);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.trust-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
}

.trust-grid div {
	display: grid;
	gap: 4px;
}

.trust-grid strong {
	color: var(--navy);
}

.trust-grid span,
.section-heading p,
.plan-card p,
.resource-card p,
.step-card p,
.faq-list p,
.site-footer p,
.footer-bottom {
	color: var(--muted);
}

.section-heading {
	max-width: 720px;
	margin-bottom: 34px;
}

.section-heading.centered {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.section-heading h2 {
	margin-bottom: 12px;
}

.steps-grid,
.resource-grid,
.plans-grid {
	display: grid;
	gap: 18px;
}

.steps-grid {
	grid-template-columns: repeat(3, 1fr);
}

.step-card,
.resource-card,
.plan-card {
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	padding: 24px;
	box-shadow: 0 10px 26px rgba(23, 43, 77, 0.04);
}

.step-card span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	margin-bottom: 20px;
	border-radius: var(--radius-sm);
	background: linear-gradient(135deg, var(--purple), var(--turquoise));
	color: var(--white);
	font-weight: 900;
}

.step-card h3,
.resource-card h3 {
	margin-bottom: 10px;
}

.resources-section {
	background: var(--white);
}

.resource-grid {
	grid-template-columns: repeat(3, 1fr);
}

.resource-card {
	background: var(--paper);
}

.plans-section {
	background: linear-gradient(180deg, #F6F8FC 0%, #FFFFFF 100%);
}

.plans-grid {
	grid-template-columns: repeat(3, 1fr);
	align-items: stretch;
}

.plan-card {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.plan-card.featured {
	border-color: rgba(91, 42, 214, 0.28);
	box-shadow: var(--shadow);
	transform: translateY(-8px);
}

.price {
	color: var(--navy);
	font-size: 38px;
	font-weight: 900;
}

.price span {
	color: var(--muted);
	font-size: 15px;
	font-weight: 700;
}

.plan-card .btn {
	margin-top: auto;
}

.faq-grid {
	display: grid;
	grid-template-columns: 0.8fr 1.2fr;
	gap: 48px;
}

.faq-list {
	display: grid;
	gap: 12px;
}

details {
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 18px 20px;
}

summary {
	cursor: pointer;
	color: var(--navy);
	font-weight: 900;
}

details p {
	margin-top: 10px;
}

.cta-section {
	padding: 0 0 86px;
}

.cta-panel {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 34px;
	border-radius: var(--radius-xl);
	background: var(--navy);
}

.cta-panel h2 {
	color: var(--white);
	max-width: 720px;
}

.cta-panel .eyebrow {
	color: var(--yellow);
}

.site-footer {
	padding: 54px 0 28px;
	background: var(--white);
	border-top: 1px solid var(--line);
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.3fr 0.7fr 1fr;
	gap: 34px;
}

.footer-logo {
	width: 150px;
	margin-bottom: 12px;
}

.site-footer h3 {
	margin-bottom: 10px;
	font-size: 16px;
}

.site-footer a {
	display: block;
	margin: 6px 0;
	color: var(--muted);
	font-weight: 700;
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	margin-top: 38px;
	padding-top: 22px;
	border-top: 1px solid var(--line);
	font-size: 14px;
}

.workspace-body {
	background: #F3F6FB;
}

.app-shell {
	min-height: 100vh;
	display: grid;
	grid-template-columns: 248px 1fr;
	background:
		linear-gradient(135deg, rgba(91, 42, 214, 0.08), rgba(0, 194, 199, 0.055) 42%, transparent 72%),
		linear-gradient(rgba(23, 43, 77, 0.024) 1px, transparent 1px),
		linear-gradient(90deg, rgba(23, 43, 77, 0.02) 1px, transparent 1px),
		#F3F6FB;
	background-size: auto, 58px 58px, 58px 58px;
	transition: grid-template-columns 180ms ease;
}

.app-shell.is-collapsed {
	grid-template-columns: 82px 1fr;
}

.app-sidebar {
	position: sticky;
	top: 0;
	height: 100vh;
	display: flex;
	flex-direction: column;
	gap: 18px;
	background: rgba(255, 255, 255, 0.84);
	color: var(--navy);
	padding: 18px 14px;
	border-right: 1px solid rgba(221, 229, 240, 0.86);
	backdrop-filter: blur(18px);
	box-shadow: 14px 0 40px rgba(23, 43, 77, 0.05);
}

.sidebar-brand {
	display: grid;
	grid-template-columns: 1fr 34px;
	align-items: center;
	gap: 10px;
	min-height: 48px;
}

.brand-symbol {
	display: none;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: var(--radius-sm);
	background: var(--white);
	border: 1px solid var(--line);
	box-shadow: 0 10px 24px rgba(23, 43, 77, 0.07);
	overflow: hidden;
}

.brand-symbol img {
	width: 33px;
	height: 33px;
	object-fit: contain;
	mix-blend-mode: multiply;
}

.brand-wordmark {
	min-width: 0;
	overflow: hidden;
	transition: opacity 160ms ease, width 160ms ease;
}

.brand-wordmark img {
	width: 150px;
	height: auto;
	mix-blend-mode: multiply;
}

.sidebar-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border: 1px solid var(--line);
	border-radius: var(--radius-sm);
	background: var(--white);
	color: var(--navy);
	cursor: pointer;
}

.sidebar-toggle svg {
	width: 18px;
	height: 18px;
	fill: none;
	stroke: currentColor;
	stroke-width: 2.4;
	stroke-linecap: round;
	stroke-linejoin: round;
	transition: transform 160ms ease;
}

.workspace-nav {
	display: grid;
	gap: 8px;
}

.workspace-nav-bottom {
	margin-top: auto;
}

.workspace-nav a {
	position: relative;
	display: grid;
	grid-template-columns: 42px 1fr;
	align-items: center;
	gap: 10px;
	min-height: 46px;
	padding: 2px 10px 2px 2px;
	border-radius: var(--radius-sm);
	color: var(--muted);
	font-weight: 900;
	overflow: hidden;
	transition: color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.workspace-nav a:hover,
.workspace-nav a.is-active {
	background: var(--white);
	color: var(--purple);
	box-shadow: 0 10px 24px rgba(23, 43, 77, 0.07);
}

.workspace-nav a.is-active:before {
	content: "";
	position: absolute;
	left: 0;
	top: 10px;
	bottom: 10px;
	width: 3px;
	border-radius: 999px;
	background: linear-gradient(180deg, var(--purple), var(--turquoise));
}

.nav-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: var(--radius-sm);
}

.workspace-nav svg,
.creation-icon svg,
.sidebar-toggle svg,
.payment-status svg {
	fill: none;
	stroke: currentColor;
	stroke-width: 2.2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.nav-icon svg {
	width: 21px;
	height: 21px;
}

.nav-label {
	white-space: nowrap;
	transition: opacity 140ms ease, transform 140ms ease;
}

.app-shell.is-collapsed .brand-wordmark,
.app-shell.is-collapsed .nav-label {
	width: 0;
	opacity: 0;
	transform: translateX(-6px);
	pointer-events: none;
}

.app-shell.is-collapsed .brand-symbol {
	display: flex;
}

.app-shell.is-collapsed .sidebar-brand {
	grid-template-columns: 42px;
	justify-content: center;
}

.app-shell.is-collapsed .sidebar-toggle {
	position: absolute;
	top: 66px;
	left: 50%;
	transform: translateX(-50%);
}

.app-shell.is-collapsed .sidebar-toggle svg {
	transform: rotate(180deg);
}

.app-shell.is-collapsed .workspace-nav {
	margin-top: 42px;
}

.app-shell.is-collapsed .workspace-nav a {
	grid-template-columns: 42px;
	justify-content: center;
	padding-right: 2px;
	overflow: visible;
}

.app-shell.is-collapsed .workspace-nav a[data-tooltip]:after,
.app-shell.is-collapsed .workspace-nav a[data-tooltip]:before {
	position: absolute;
	top: 50%;
	left: calc(100% + 10px);
	z-index: 30;
	opacity: 0;
	pointer-events: none;
	transition: opacity 140ms ease, transform 140ms ease;
}

.app-shell.is-collapsed .workspace-nav a[data-tooltip]:after {
	content: attr(data-tooltip);
	min-width: max-content;
	padding: 8px 10px;
	border-radius: var(--radius-sm);
	background: var(--navy);
	color: var(--white);
	font-size: 12px;
	font-weight: 900;
	line-height: 1;
	box-shadow: 0 12px 28px rgba(23, 43, 77, 0.18);
	transform: translate(4px, -50%);
}

.app-shell.is-collapsed .workspace-nav a[data-tooltip]:before {
	content: "";
	width: 8px;
	height: 8px;
	background: var(--navy);
	transform: translate(0, -50%) rotate(45deg);
}

.app-shell.is-collapsed .workspace-nav a[data-tooltip]:hover:after,
.app-shell.is-collapsed .workspace-nav a[data-tooltip]:focus-visible:after {
	opacity: 1;
	transform: translate(0, -50%);
}

.app-shell.is-collapsed .workspace-nav a[data-tooltip]:hover:before,
.app-shell.is-collapsed .workspace-nav a[data-tooltip]:focus-visible:before {
	opacity: 1;
	transform: translate(-4px, -50%) rotate(45deg);
}

.app-main {
	min-width: 0;
	display: flex;
	flex-direction: column;
}

.app-topbar {
	position: sticky;
	top: 0;
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	min-height: 56px;
	padding: 8px 28px;
	background: rgba(243, 246, 251, 0.78);
	border-bottom: 1px solid rgba(221, 229, 240, 0.42);
	backdrop-filter: blur(18px);
}

.topbar-title {
	display: grid;
	gap: 2px;
}

.topbar-title span {
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.topbar-title strong {
	color: var(--navy);
	font-family: "Poppins", Arial, sans-serif;
	font-size: 17px;
}

.topbar-actions {
	display: flex;
	align-items: center;
	gap: 10px;
}

.topbar-create,
.credits-pill,
.account-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	border-radius: 999px;
	font-weight: 900;
}

.topbar-create {
	padding: 10px 14px;
	color: var(--white);
	background: linear-gradient(135deg, var(--purple), var(--turquoise));
	box-shadow: 0 12px 24px rgba(91, 42, 214, 0.18);
}

.credits-pill {
	gap: 8px;
	background: rgba(255, 209, 102, 0.34);
	color: #604400;
	padding: 9px 14px;
}

.account-pill {
	padding: 9px 14px;
	color: var(--navy);
	background: rgba(255, 255, 255, 0.8);
	border: 1px solid rgba(255, 255, 255, 0.92);
	box-shadow: 0 10px 24px rgba(23, 43, 77, 0.055);
}

.account-pill:hover {
	color: var(--purple);
	border-color: rgba(91, 42, 214, 0.28);
	box-shadow: 0 10px 24px rgba(23, 43, 77, 0.07);
}

.app-content {
	width: min(1480px, 100%);
	margin: 0 auto;
	padding: 18px 28px 34px;
}

.auth-section {
	padding: 72px 0 86px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(246, 248, 252, 0.88)),
		linear-gradient(rgba(23, 43, 77, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(23, 43, 77, 0.035) 1px, transparent 1px);
	background-size: auto, 64px 64px, 64px 64px;
}

.auth-grid {
	display: grid;
	grid-template-columns: 0.85fr 1fr;
	gap: 56px;
	align-items: start;
}

.auth-copy {
	position: sticky;
	top: 110px;
	padding-top: 22px;
}

.auth-copy h1 {
	font-size: clamp(38px, 5vw, 58px);
	margin-bottom: 18px;
}

.auth-copy p:not(.eyebrow),
.auth-intro,
.auth-switch {
	color: var(--muted);
}

.auth-panel,
.dashboard-hero,
.credits-hero,
.metric-panel,
.quick-actions,
.history-panel,
.empty-state,
.credit-alert,
.credit-rules,
.extra-card {
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	box-shadow: 0 16px 42px rgba(23, 43, 77, 0.06);
}

.auth-panel {
	padding: 30px;
}

.auth-panel h2 {
	font-size: 30px;
	margin-bottom: 8px;
}

.auth-form {
	display: grid;
	gap: 12px;
	margin-top: 22px;
}

.auth-form label {
	color: var(--navy);
	font-size: 13px;
	font-weight: 900;
}

.auth-form input,
.auth-form select {
	width: 100%;
	min-height: 48px;
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	background: var(--white);
	color: var(--navy);
	font: inherit;
	padding: 10px 12px;
	outline: none;
}

.auth-form input:focus,
.auth-form select:focus {
	border-color: rgba(91, 42, 214, 0.58);
	box-shadow: 0 0 0 4px rgba(91, 42, 214, 0.1);
}

.form-two {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.material-form .form-two {
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 14px;
}

.form-alert {
	margin-top: 16px;
	padding: 12px 14px;
	border-radius: var(--radius-md);
	background: rgba(255, 209, 102, 0.22);
	border: 1px solid rgba(255, 209, 102, 0.54);
	color: #6F5200;
	font-weight: 800;
}

.workspace-alert {
	margin-top: 18px;
}

.field-help {
	margin-top: 6px;
	color: var(--muted);
	font-size: 12px;
	font-weight: 800;
}

.field-help.is-error {
	color: #B42318;
}

.field-help.is-ok {
	color: #087F5B;
}

.auth-switch {
	margin-top: 18px;
	text-align: center;
}

.auth-switch a {
	color: var(--purple);
	font-weight: 900;
}

.dashboard-hero {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
	padding: 36px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(241, 251, 251, 0.9)),
		linear-gradient(90deg, rgba(91, 42, 214, 0.09), transparent 58%);
}

.dashboard-hero h1,
.credits-hero h1 {
	font-size: clamp(34px, 4vw, 50px);
	margin-bottom: 8px;
}

.dashboard-hero p:not(.eyebrow),
.credits-hero p:not(.eyebrow) {
	color: var(--muted);
	max-width: 680px;
	font-size: 17px;
	line-height: 1.65;
}

.creation-studio {
	margin-top: 0;
}

.credit-alert + .creation-studio {
	margin-top: 20px;
}

.creation-studio .section-heading {
	margin-bottom: 16px;
}

.creation-studio h2 {
	font-size: 28px;
}

.creation-grid {
	display: grid;
	grid-template-columns: 1.2fr repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.creation-card {
	position: relative;
	display: flex;
	min-height: 188px;
	flex-direction: column;
	align-items: flex-start;
	justify-content: space-between;
	gap: 14px;
	padding: 22px;
	overflow: hidden;
	border: 1px solid rgba(221, 229, 240, 0.92);
	border-radius: var(--radius-lg);
	background: rgba(255, 255, 255, 0.94);
	box-shadow: 0 16px 42px rgba(23, 43, 77, 0.055);
	transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.creation-card:hover {
	transform: translateY(-2px);
	border-color: rgba(91, 42, 214, 0.3);
	background: var(--white);
	box-shadow: 0 22px 50px rgba(23, 43, 77, 0.09);
}

.creation-card.is-featured {
	grid-row: span 2;
	min-height: 390px;
	padding: 28px;
	color: var(--white);
	border-color: rgba(91, 42, 214, 0.18);
	background:
		linear-gradient(145deg, rgba(91, 42, 214, 0.96), rgba(19, 76, 148, 0.92) 54%, rgba(0, 194, 199, 0.9)),
		var(--purple);
	box-shadow: 0 26px 68px rgba(91, 42, 214, 0.22);
}

.creation-card.is-featured:after {
	content: "";
	position: absolute;
	inset: auto -18% -34% 22%;
	height: 52%;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.16) 1px, transparent 1px),
		linear-gradient(rgba(255, 255, 255, 0.12) 1px, transparent 1px);
	background-size: 34px 34px;
	transform: rotate(-8deg);
	pointer-events: none;
}

.creation-icon {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: var(--radius-sm);
	color: var(--purple);
	background: rgba(91, 42, 214, 0.08);
}

.creation-card.is-featured .creation-icon {
	width: 58px;
	height: 58px;
	color: var(--white);
	background: rgba(255, 255, 255, 0.16);
}

.creation-icon svg {
	width: 25px;
	height: 25px;
}

.creation-card strong,
.creation-card p,
.creation-card em {
	position: relative;
	z-index: 1;
}

.creation-card strong {
	display: block;
	color: var(--navy);
	font-family: "Poppins", Arial, sans-serif;
	font-size: 22px;
	line-height: 1.15;
}

.creation-card.is-featured strong {
	color: var(--white);
	font-size: 34px;
}

.creation-card p {
	max-width: 280px;
	color: var(--muted);
	line-height: 1.55;
}

.creation-card.is-featured p {
	max-width: 330px;
	color: rgba(255, 255, 255, 0.82);
	font-size: 17px;
}

.creation-card em {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 30px;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(0, 194, 199, 0.1);
	color: #06767A;
	font-size: 12px;
	font-style: normal;
	font-weight: 900;
	text-transform: uppercase;
}

.creation-card.is-featured em {
	color: var(--navy);
	background: rgba(255, 255, 255, 0.86);
}

.workspace-summary {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	margin-top: 20px;
}

.summary-card {
	display: block;
	min-height: 126px;
	padding: 20px;
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 14px 34px rgba(23, 43, 77, 0.045);
}

.summary-card:hover {
	border-color: rgba(91, 42, 214, 0.26);
	background: var(--white);
}

.summary-card span {
	display: block;
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.summary-card strong {
	display: block;
	margin: 8px 0 4px;
	color: var(--navy);
	font-family: "Poppins", Arial, sans-serif;
	font-size: 20px;
	line-height: 1.22;
}

.summary-card p {
	color: var(--muted);
	font-size: 14px;
	line-height: 1.5;
}

.credits-hero,
.credit-alert {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
	padding: 30px;
}

.credit-alert {
	margin-top: 18px;
	background: rgba(255, 209, 102, 0.18);
	border-color: rgba(255, 209, 102, 0.48);
}

.credit-alert strong {
	display: block;
	color: var(--navy);
	margin-bottom: 4px;
}

.credit-alert p {
	color: #6F5200;
}

.dashboard-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-top: 18px;
}

.metric-panel {
	padding: 22px;
	min-height: 148px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.metric-panel span {
	display: block;
	color: var(--muted);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}

.metric-panel strong {
	display: block;
	margin: 8px 0;
	color: var(--navy);
	font-size: 34px;
	font-weight: 900;
}

.metric-panel p,
.empty-state p {
	color: var(--muted);
}

.quick-actions,
.history-panel,
.plans-private {
	margin-top: 20px;
	padding: 26px;
}

.quick-actions .section-heading,
.history-panel .section-heading {
	margin-bottom: 18px;
}

.quick-actions h2,
.history-panel h2 {
	font-size: 30px;
}

.quick-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 12px;
}

.quick-grid a {
	display: grid;
	align-items: start;
	gap: 8px;
	min-height: 72px;
	padding: 16px;
	border-radius: var(--radius-md);
	background: var(--paper);
	border: 1px solid var(--line);
	color: var(--navy);
	font-weight: 900;
}

.quick-grid a:hover {
	border-color: rgba(91, 42, 214, 0.28);
	color: var(--purple);
	background: var(--white);
	box-shadow: 0 14px 28px rgba(23, 43, 77, 0.07);
	transform: translateY(-1px);
}

.quick-grid a span {
	color: var(--turquoise);
	font-size: 12px;
	font-weight: 900;
}

.quick-grid a strong {
	font-size: 16px;
	line-height: 1.2;
}

.quick-grid a em {
	color: var(--muted);
	font-size: 12px;
	font-style: normal;
}

.history-list {
	display: grid;
	gap: 10px;
}

.movement-list {
	display: grid;
	gap: 10px;
}

.movement-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px;
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	background: var(--paper);
}

.movement-row strong {
	display: block;
	color: var(--navy);
}

.movement-row span {
	display: block;
	color: var(--muted);
	font-size: 13px;
}

.movement-row em {
	font-style: normal;
	font-weight: 900;
	white-space: nowrap;
}

.movement-row em.is-positive {
	color: #087F5B;
}

.movement-row em.is-negative {
	color: #B42318;
}

.credit-rules {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
	margin-top: 18px;
	padding: 24px;
}

.credit-rules strong {
	display: block;
	color: var(--navy);
	margin-bottom: 6px;
}

.credit-rules p {
	color: var(--muted);
}

.extra-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.extra-card {
	padding: 22px;
}

.extra-card span {
	color: var(--muted);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}

.extra-card strong {
	display: block;
	margin: 8px 0;
	color: var(--navy);
	font-size: 30px;
}

.extra-card p {
	color: var(--muted);
	margin-bottom: 16px;
}

.payment-confirmation {
	display: grid;
	gap: 18px;
}

.payment-hero,
.payment-card,
.payment-detail-card,
.payment-next {
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	box-shadow: 0 16px 42px rgba(23, 43, 77, 0.06);
}

.payment-hero {
	padding: 34px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(238, 250, 251, 0.82)),
		linear-gradient(90deg, rgba(91, 42, 214, 0.09), transparent 64%);
}

.payment-status {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 18px;
	padding: 8px 12px;
	border-radius: 999px;
	font-weight: 900;
}

.payment-status span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--white);
}

.payment-status.is-success {
	color: #087F5B;
	background: rgba(8, 127, 91, 0.12);
}

.payment-status.is-cancel {
	color: #8A5A00;
	background: rgba(255, 209, 102, 0.24);
}

.payment-hero h1 {
	font-size: clamp(42px, 5vw, 64px);
	margin-bottom: 10px;
}

.payment-hero p {
	max-width: 820px;
	color: var(--muted);
	font-size: 18px;
}

.payment-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 24px;
}

.payment-summary-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.payment-card {
	padding: 22px;
}

.payment-card span,
.payment-detail-list span {
	display: block;
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.payment-card strong {
	display: block;
	margin: 8px 0;
	color: var(--navy);
	font-size: 28px;
	font-weight: 900;
}

.payment-card p,
.payment-detail-card p,
.payment-next p {
	color: var(--muted);
}

.payment-detail-card {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	padding: 28px;
	align-items: start;
}

.payment-detail-card h2 {
	margin-bottom: 8px;
}

.payment-detail-list {
	display: grid;
	gap: 10px;
}

.payment-detail-list div {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px;
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	background: var(--paper);
}

.payment-detail-list strong {
	color: var(--navy);
	text-align: right;
}

.payment-next {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	padding: 24px;
}

.payment-next strong {
	display: block;
	margin-bottom: 6px;
	color: var(--navy);
}

.history-row {
	display: grid;
	grid-template-columns: 1fr 180px 170px;
	gap: 12px;
	align-items: center;
	padding: 14px;
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	background: var(--paper);
}

.history-row strong {
	color: var(--navy);
}

.history-row span {
	color: var(--muted);
}

.empty-state {
	padding: 22px;
}

.empty-state strong {
	display: block;
	margin-bottom: 4px;
	color: var(--navy);
}

.material-flow-hero,
.material-panel,
.material-summary-panel,
.material-type-list {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(255, 255, 255, 0.9);
	border-radius: var(--radius-lg);
	box-shadow: 0 22px 54px rgba(23, 43, 77, 0.075);
	backdrop-filter: blur(18px);
}

.material-flow-hero {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 22px 24px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(246, 253, 253, 0.9)),
		linear-gradient(90deg, rgba(91, 42, 214, 0.1), rgba(0, 194, 199, 0.09));
}

.material-flow-hero h1 {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: clamp(25px, 3vw, 36px);
}

.material-flow-hero p:not(.eyebrow),
.material-cost-panel p,
.material-summary-panel p {
	color: var(--muted);
}

.material-cost-panel {
	min-width: 180px;
	padding: 14px 16px;
	border-radius: var(--radius-md);
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(255, 255, 255, 0.94);
	box-shadow: 0 14px 34px rgba(23, 43, 77, 0.06);
}

.material-cost-panel span,
.panel-heading span,
.material-summary-panel span {
	display: block;
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.material-cost-panel strong {
	display: block;
	margin: 4px 0 1px;
	color: var(--navy);
	font-size: 22px;
	font-weight: 900;
}

.material-cost-panel em {
	color: var(--muted);
	font-size: 12px;
	font-style: normal;
	font-weight: 900;
}

.material-credit-alert {
	margin-bottom: 18px;
}

.material-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 330px;
	gap: 18px;
	margin-top: 18px;
	align-items: start;
}

.material-layout-wide {
	grid-template-columns: minmax(0, 1fr);
}

.material-form {
	display: grid;
	gap: 16px;
}

.material-hidden-fields {
	display: none;
}

.material-panel {
	display: grid;
	gap: 16px;
	padding: 24px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.76)),
		linear-gradient(135deg, rgba(91, 42, 214, 0.045), rgba(0, 194, 199, 0.04));
	transition: border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.material-panel:focus-within {
	border-color: rgba(91, 42, 214, 0.22);
	box-shadow: 0 24px 62px rgba(23, 43, 77, 0.09);
}

.ai-search-panel {
	gap: 14px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(244, 252, 252, 0.82)),
		linear-gradient(90deg, rgba(91, 42, 214, 0.08), rgba(0, 194, 199, 0.08));
}

.ai-search-heading {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
}

.ai-search-heading span,
.ai-search-heading strong {
	display: block;
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.ai-search-heading h2 {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 3px;
	font-size: 25px;
}

.ai-prompt-box {
	display: grid;
	gap: 12px;
	padding: 10px;
	border: 1px solid rgba(221, 229, 240, 0.74);
	border-radius: var(--radius-lg);
	background: rgba(255, 255, 255, 0.72);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.ai-prompt-box textarea {
	width: 100%;
	min-height: 104px;
	border: 0;
	background: transparent;
	color: var(--navy);
	font: inherit;
	font-size: 16px;
	line-height: 1.55;
	padding: 10px 12px 0;
	outline: none;
	resize: vertical;
}

.ai-prompt-box textarea::placeholder {
	color: #8793A8;
}

.ai-prompt-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex-wrap: wrap;
}

.ai-search-status {
	min-height: 24px;
	color: var(--muted);
	font-size: 13px;
	font-weight: 800;
}

.ai-search-status.is-loading {
	color: var(--purple);
}

.ai-search-status.is-success {
	color: #087F5B;
}

.ai-search-status.is-empty {
	color: #8A5A00;
}

.ai-search-results {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 12px;
}

.ai-result-card {
	position: relative;
	display: grid;
	gap: 9px;
	min-height: 190px;
	padding: 16px;
	border: 1px solid rgba(221, 229, 240, 0.86);
	border-radius: var(--radius-lg);
	background: rgba(255, 255, 255, 0.88);
	color: var(--text);
	font: inherit;
	text-align: left;
	box-shadow: 0 12px 28px rgba(23, 43, 77, 0.045);
	cursor: pointer;
	transition: transform 150ms ease, border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}

.ai-result-card:hover,
.ai-result-card.is-selected {
	transform: translateY(-1px);
	border-color: rgba(91, 42, 214, 0.32);
	background: var(--white);
	box-shadow: 0 18px 42px rgba(23, 43, 77, 0.08);
}

.ai-result-card.is-selected {
	box-shadow: 0 0 0 4px rgba(91, 42, 214, 0.09), 0 18px 42px rgba(23, 43, 77, 0.08);
}

.ai-result-card.is-selected:after {
	content: "";
	position: absolute;
	top: 14px;
	right: 14px;
	width: 20px;
	height: 20px;
	border-radius: var(--radius-pill);
	background:
		linear-gradient(135deg, var(--purple), var(--turquoise));
	box-shadow: 0 8px 18px rgba(91, 42, 214, 0.16);
}

.ai-result-card.is-selected:before {
	content: "";
	position: absolute;
	top: 19px;
	right: 20px;
	z-index: 1;
	width: 7px;
	height: 4px;
	border-left: 2px solid var(--white);
	border-bottom: 2px solid var(--white);
	transform: rotate(-45deg);
}

.ai-result-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.ai-result-meta span {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 5px 9px;
	border-radius: var(--radius-pill);
	background: rgba(91, 42, 214, 0.08);
	color: var(--purple);
	font-size: 11px;
	font-weight: 900;
}

.ai-result-card strong {
	display: block;
	color: var(--navy);
	font-family: "Poppins", Arial, sans-serif;
	font-size: 16px;
	line-height: 1.28;
}

.ai-result-card p {
	color: var(--muted);
	font-size: 13px;
	line-height: 1.45;
}

.panel-heading {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 2px;
}

.panel-heading h2 {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 3px;
	font-size: 23px;
}

.material-form label {
	display: block;
	margin-bottom: 7px;
	color: var(--navy);
	font-size: 13px;
	font-weight: 900;
}

.material-form label small {
	color: var(--muted);
	font-size: 12px;
	font-weight: 800;
}

.material-form input[type="text"],
.material-form select,
.material-form textarea {
	width: 100%;
	min-height: 54px;
	border: 1px solid rgba(221, 229, 240, 0.86);
	border-radius: var(--radius-md);
	background: rgba(255, 255, 255, 0.86);
	color: var(--navy);
	font: inherit;
	padding: 12px 15px;
	outline: none;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.material-form textarea {
	min-height: 132px;
	resize: vertical;
}

.material-form input:focus,
.material-form select:focus,
.material-form textarea:focus {
	border-color: rgba(91, 42, 214, 0.36);
	background: var(--white);
	box-shadow: 0 0 0 5px rgba(91, 42, 214, 0.09), 0 12px 28px rgba(23, 43, 77, 0.06);
}

.material-form .ai-prompt-box textarea,
.material-form .ai-prompt-box textarea:focus {
	min-height: 104px;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	padding: 10px 12px 0;
}

.native-select-hidden {
	position: absolute;
	width: 1px !important;
	height: 1px !important;
	min-height: 1px !important;
	padding: 0 !important;
	border: 0 !important;
	opacity: 0;
	pointer-events: none;
}

.select-combobox {
	position: relative;
}

.select-combobox-input {
	width: 100%;
	min-height: 54px;
	border: 1px solid rgba(221, 229, 240, 0.86);
	border-radius: var(--radius-md);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(250, 252, 255, 0.9));
	color: var(--navy);
	font: inherit;
	padding: 12px 46px 12px 15px;
	outline: none;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

.select-combobox:after {
	content: "";
	position: absolute;
	top: 22px;
	right: 18px;
	width: 9px;
	height: 9px;
	border-right: 2px solid var(--muted);
	border-bottom: 2px solid var(--muted);
	pointer-events: none;
	transform: rotate(45deg);
}

.select-combobox-input:focus {
	border-color: rgba(91, 42, 214, 0.36);
	background: var(--white);
	box-shadow: 0 0 0 5px rgba(91, 42, 214, 0.09), 0 12px 28px rgba(23, 43, 77, 0.06);
}

.auth-form .select-combobox-input {
	min-height: 48px;
	border-color: var(--line);
	background: var(--white);
	padding-top: 10px;
	padding-bottom: 10px;
}

.auth-form .select-combobox:after {
	top: 19px;
}

.select-combobox-list {
	position: absolute;
	left: 0;
	right: 0;
	top: calc(100% + 8px);
	z-index: 35;
	display: none;
	max-height: 280px;
	padding: 8px;
	overflow: auto;
	border: 1px solid rgba(221, 229, 240, 0.9);
	border-radius: var(--radius-md);
	background: rgba(255, 255, 255, 0.98);
	box-shadow: 0 24px 54px rgba(23, 43, 77, 0.16);
}

.select-combobox.is-open .select-combobox-list {
	display: grid;
	gap: 4px;
}

.select-combobox-option {
	width: 100%;
	padding: 10px 12px;
	border: 0;
	border-radius: var(--radius-sm);
	background: transparent;
	color: var(--navy);
	font: inherit;
	font-size: 14px;
	font-weight: 750;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
}

.select-combobox-option:hover,
.select-combobox-option.is-selected {
	background:
		linear-gradient(135deg, rgba(91, 42, 214, 0.1), rgba(0, 194, 199, 0.08));
	color: var(--purple);
}

.select-combobox-empty {
	padding: 12px;
	color: var(--muted);
	font-size: 13px;
	font-weight: 800;
}

.form-three {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
}

.resource-checks {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 4px;
}

.resource-checks label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 42px;
	margin: 0;
	padding: 9px 13px;
	border: 1px solid rgba(221, 229, 240, 0.78);
	border-radius: 999px;
	background: rgba(246, 248, 252, 0.86);
	color: var(--navy);
	cursor: pointer;
	transition: border-color 150ms ease, background 150ms ease, box-shadow 150ms ease;
}

.resource-checks label:hover {
	border-color: rgba(91, 42, 214, 0.26);
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 10px 22px rgba(23, 43, 77, 0.055);
}

.resource-checks input {
	margin: 0;
	accent-color: var(--purple);
}

.resource-checks span {
	font-size: 13px;
	font-weight: 800;
}

.context-toggle {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0;
	padding: 16px 18px;
	border: 1px solid rgba(221, 229, 240, 0.78);
	border-radius: var(--radius-lg);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(246, 248, 252, 0.78));
	cursor: pointer;
}

.context-toggle input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.context-toggle > span {
	position: relative;
	width: 52px;
	height: 30px;
	border-radius: 999px;
	background: #C9D3E3;
	transition: background 160ms ease;
}

.context-toggle > span:after {
	content: "";
	position: absolute;
	top: 4px;
	left: 4px;
	width: 22px;
	height: 22px;
	border-radius: 999px;
	background: var(--white);
	box-shadow: 0 4px 12px rgba(23, 43, 77, 0.18);
	transition: transform 160ms ease;
}

.context-toggle input:checked + span {
	background: linear-gradient(135deg, var(--purple), var(--turquoise));
}

.context-toggle input:checked + span:after {
	transform: translateX(22px);
}

.context-toggle strong {
	color: var(--navy);
	font-size: 15px;
}

.context-toggle-hero {
	justify-content: space-between;
	gap: 14px;
	min-width: 210px;
	margin-top: 6px;
	padding: 10px 12px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
}

.context-toggle-hero > span {
	order: 2;
	width: 58px;
	height: 34px;
}

.context-toggle-hero > span:after {
	width: 26px;
	height: 26px;
}

.context-toggle-hero input:checked + span:after {
	transform: translateX(24px);
}

.context-toggle-hero strong {
	font-size: 16px;
}

.context-status {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 16px 18px;
	border: 1px solid rgba(221, 229, 240, 0.78);
	border-radius: var(--radius-lg);
	background: rgba(246, 248, 252, 0.78);
}

.context-status.is-active {
	border-color: rgba(0, 194, 199, 0.22);
	background:
		linear-gradient(135deg, rgba(0, 194, 199, 0.12), rgba(91, 42, 214, 0.07)),
		rgba(255, 255, 255, 0.84);
}

.context-status strong {
	display: block;
	color: var(--navy);
}

.context-status p {
	color: var(--muted);
}

.context-state-panel strong {
	font-size: 24px;
}

.review-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.review-grid div,
.review-block {
	padding: 16px;
	border: 1px solid rgba(221, 229, 240, 0.78);
	border-radius: var(--radius-md);
	background: rgba(246, 248, 252, 0.74);
}

.review-grid span,
.review-block span {
	display: block;
	margin-bottom: 5px;
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.review-grid strong,
.review-block strong {
	display: block;
	color: var(--navy);
	font-size: 15px;
	line-height: 1.45;
}

.review-block p {
	color: var(--text);
}

.pda-review-panel {
	gap: 18px;
}

.pda-overview {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.pda-card-list {
	display: grid;
	gap: 12px;
}

.project-card-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 12px;
}

.pda-review-card {
	display: grid;
	gap: 13px;
	padding: 18px;
	border: 1px solid rgba(221, 229, 240, 0.82);
	border-radius: var(--radius-lg);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(246, 248, 252, 0.78));
	box-shadow: 0 14px 32px rgba(23, 43, 77, 0.05);
}

.pda-review-card span {
	display: block;
	margin-bottom: 5px;
	color: var(--muted);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.pda-review-card strong {
	display: block;
	color: var(--navy);
	font-family: "Poppins", Arial, sans-serif;
	font-size: 17px;
	line-height: 1.35;
}

.pda-review-card p {
	color: var(--text);
	line-height: 1.55;
}

.project-review-card {
	display: grid;
	gap: 12px;
	align-content: start;
	min-height: 220px;
	padding: 18px;
	border: 1px solid rgba(221, 229, 240, 0.82);
	border-radius: var(--radius-lg);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(241, 251, 251, 0.78));
	box-shadow: 0 14px 32px rgba(23, 43, 77, 0.05);
}

.project-review-card strong {
	display: block;
	color: var(--navy);
	font-family: "Poppins", Arial, sans-serif;
	font-size: 18px;
	line-height: 1.3;
}

.project-review-card p {
	color: var(--text);
	line-height: 1.55;
}

.project-review-card em {
	align-self: end;
	color: var(--muted);
	font-size: 12px;
	font-style: normal;
	font-weight: 900;
	text-transform: uppercase;
}

.project-empty-state {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(246, 248, 252, 0.82));
}

.resource-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.resource-pills span {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 7px 12px;
	border-radius: 999px;
	background: rgba(91, 42, 214, 0.09);
	color: var(--purple);
	font-size: 12px;
	font-weight: 900;
}

.material-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 2px 0;
}

.material-actions form {
	margin: 0;
}

.material-actions .btn,
.material-form .btn {
	border-radius: 999px;
}

.material-summary {
	position: sticky;
	top: 92px;
	display: grid;
	gap: 12px;
}

.material-summary-panel {
	padding: 18px;
}

.material-summary-panel strong {
	display: block;
	margin: 6px 0;
	color: var(--navy);
	font-size: 20px;
	font-weight: 900;
}

.flow-steps {
	display: grid;
	gap: 8px;
	margin: 10px 0 0;
	padding: 0;
	list-style: none;
}

.flow-steps li {
	padding: 10px 12px;
	border-radius: var(--radius-sm);
	background: var(--paper);
	color: var(--muted);
	font-size: 13px;
	font-weight: 900;
}

.flow-steps li.is-active {
	background: rgba(91, 42, 214, 0.1);
	color: var(--purple);
}

.material-type-list {
	display: grid;
	gap: 8px;
	padding: 10px;
}

.material-type-list a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 12px;
	border-radius: var(--radius-sm);
	color: var(--navy);
	font-weight: 900;
}

.material-type-list a:hover,
.material-type-list a.is-active {
	background: var(--paper);
	color: var(--purple);
}

.material-type-list em {
	color: var(--muted);
	font-size: 12px;
	font-style: normal;
	white-space: nowrap;
}

.form-alert.is-success {
	background: rgba(8, 127, 91, 0.12);
	border-color: rgba(8, 127, 91, 0.28);
	color: #087F5B;
}

@media (max-width: 920px) {
	.site-nav,
	.nav-actions {
		display: none;
	}

	.nav-toggle {
		display: block;
	}

	.mobile-nav.is-open {
		display: block;
	}

	.hero-grid,
	.faq-grid,
	.footer-grid {
		grid-template-columns: 1fr;
	}

	.hero {
		padding-top: 64px;
	}

	.trust-grid,
	.steps-grid,
	.resource-grid,
	.plans-grid {
		grid-template-columns: 1fr;
	}

	.plan-card.featured {
		transform: none;
	}

	.cta-panel,
	.footer-bottom {
		align-items: flex-start;
		flex-direction: column;
	}

	.app-shell {
		grid-template-columns: 1fr;
		padding-bottom: 78px;
	}

	.app-sidebar {
		position: fixed;
		left: 14px;
		right: 14px;
		top: auto;
		bottom: 12px;
		z-index: 20;
		height: 62px;
		display: block;
		padding: 8px;
		border: 1px solid rgba(221, 229, 240, 0.92);
		border-radius: var(--radius-md);
		box-shadow: 0 16px 38px rgba(23, 43, 77, 0.18);
	}

	.sidebar-brand,
	.workspace-nav-bottom,
	.nav-label {
		display: none;
	}

	.workspace-nav {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 4px;
		margin: 0;
	}

	.workspace-nav a,
	.app-shell.is-collapsed .workspace-nav a {
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 46px;
		padding: 0;
	}

	.workspace-nav a.is-active:before {
		top: auto;
		left: 50%;
		bottom: 2px;
		width: 18px;
		height: 3px;
		transform: translateX(-50%);
	}

	.app-topbar,
	.app-content {
		padding-left: 20px;
		padding-right: 20px;
	}

	.app-topbar {
		align-items: center;
		flex-direction: row;
		min-height: 52px;
		padding-top: 8px;
		padding-bottom: 8px;
	}

	.topbar-actions {
		margin-left: auto;
	}

	.auth-grid,
	.dashboard-grid {
		grid-template-columns: 1fr;
	}

	.auth-copy {
		position: static;
	}

	.dashboard-hero {
		align-items: flex-start;
		flex-direction: column;
	}

	.creation-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.creation-card.is-featured {
		grid-column: 1 / -1;
		grid-row: auto;
		min-height: 260px;
	}

	.workspace-summary {
		grid-template-columns: 1fr;
	}

	.credits-hero,
	.credit-alert {
		align-items: flex-start;
		flex-direction: column;
	}

	.quick-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.history-row,
	.credit-rules,
	.extra-grid,
	.payment-summary-grid,
	.payment-detail-card,
	.payment-next,
	.material-layout,
	.form-three,
	.pda-overview,
	.review-grid {
		grid-template-columns: 1fr;
	}

	.material-summary {
		position: static;
	}

	.material-flow-hero {
		align-items: flex-start;
		flex-direction: column;
	}

	.material-cost-panel {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 10px;
		width: 100%;
		min-width: 0;
		padding: 10px 12px;
		border-radius: var(--radius-pill);
	}

	.material-cost-panel span {
		display: none;
	}

	.material-cost-panel strong {
		margin: 0;
		font-size: 16px;
	}

	.ai-search-heading {
		flex-direction: column;
	}

	.context-status {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (max-width: 560px) {
	.container {
		width: min(100% - 28px, 1120px);
	}

	.brand-logo {
		width: 138px;
	}

	.hero-actions .btn,
	.cta-panel .btn {
		width: 100%;
	}

	.selector-grid,
	.product-card {
		grid-template-columns: 1fr;
		display: grid;
	}

	.form-two,
	.form-three,
	.quick-grid {
		grid-template-columns: 1fr;
	}

	.material-panel,
	.material-flow-hero {
		padding: 20px;
	}

	.material-flow-hero {
		gap: 14px;
	}

	.material-flow-hero h1 {
		font-size: 26px;
	}

	.ai-prompt-actions {
		align-items: stretch;
		flex-direction: column;
	}

	.ai-prompt-actions .btn {
		width: 100%;
	}

	.ai-search-results {
		grid-template-columns: 1fr;
	}

	.material-actions {
		align-items: stretch;
		flex-direction: column-reverse;
	}

	.material-actions .btn,
	.material-actions form {
		width: 100%;
	}

	.topbar-actions {
		width: auto;
		display: flex;
		gap: 8px;
	}

	.topbar-create,
	.credits-pill,
	.account-pill {
		width: auto;
		min-height: 34px;
		padding: 8px 10px;
		font-size: 12px;
	}

	.creation-grid {
		grid-template-columns: 1fr;
	}

	.creation-card,
	.creation-card.is-featured {
		min-height: 176px;
		padding: 20px;
	}

	.creation-card.is-featured strong {
		font-size: 28px;
	}

	.movement-row {
		align-items: flex-start;
		flex-direction: column;
	}

	h1 {
		font-size: 40px;
	}

	.hero-subtitle {
		font-size: 17px;
	}

	.section {
		padding: 62px 0;
	}
}
