/* ==========================================================================
   Fred AI CRM — main.css
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Design tokens
   -------------------------------------------------------------------------- */
:root {
	/* Brand colors */
	--color-orange:        #FF6B2C;
	--color-orange-dark:   #E5571A;
	--color-orange-soft:   #FFF1E8;
	--color-orange-tint:   #FFE4D2;

	--color-navy:          #0F1B2D;
	--color-navy-soft:     #1A2942;

	--color-blue:          #2D7FE8;
	--color-blue-soft:     #E3F0FF;
	--color-purple:        #8B6FCB;
	--color-purple-soft:   #EBE4F7;
	--color-green:         #2BB673;
	--color-green-soft:    #D9F2E5;
	--color-cloud-blue:    #4A90E2;

	/* Neutrals */
	--color-ink:           #1A1A2E;
	--color-ink-soft:      #4A4A5E;
	--color-muted:         #6B7280;
	--color-line:          #E7E9EE;
	--color-line-soft:     #F1F2F5;
	--color-bg:            #FFFFFF;
	--color-bg-soft:       #FAFAFB;
	--color-bg-warm:       #FFF8F2;

	/* Typography */
	--font-display: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

	/* Layout */
	--container-max: 1280px;
	--container-pad: 24px;

	/* Radii */
	--radius-sm:  8px;
	--radius-md:  12px;
	--radius-lg:  16px;
	--radius-xl:  20px;
	--radius-pill: 999px;

	/* Shadows */
	--shadow-card:  0 4px 16px rgba(15, 27, 45, 0.06), 0 1px 3px rgba(15, 27, 45, 0.04);
	--shadow-float: 0 12px 32px rgba(15, 27, 45, 0.10), 0 4px 8px rgba(15, 27, 45, 0.05);
	--shadow-cta:   0 6px 18px rgba(255, 107, 44, 0.32);

	/* Motion */
	--ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

/* --------------------------------------------------------------------------
   2. Base
   -------------------------------------------------------------------------- */
body {
	font-family: var(--font-body);
	color: var(--color-ink);
	background: var(--color-bg);
	font-size: 16px;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	color: var(--color-navy);
	margin: 0;
	line-height: 1.15;
	letter-spacing: -0.02em;
	font-weight: 800;
}

p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-pad);
}

.container--narrow {
	max-width: 760px;
}

.text-accent { color: var(--color-orange); }

.skip-link {
	background: var(--color-orange);
	color: white;
	padding: 8px 16px;
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100000;
}
.skip-link:focus { left: 0; }

/* --------------------------------------------------------------------------
   3. Buttons
   -------------------------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 20px;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 15px;
	line-height: 1;
	border-radius: var(--radius-pill);
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform 0.15s var(--ease-out), box-shadow 0.2s var(--ease-out), background 0.2s, color 0.2s;
	white-space: nowrap;
	text-decoration: none;
}

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

.btn__icon {
	display: inline-flex;
	width: 18px;
	height: 18px;
}
.btn__icon svg { width: 100%; height: 100%; }

.btn--sm { padding: 8px 14px; font-size: 13px; }
.btn--lg { padding: 16px 28px; font-size: 16px; }

.btn--primary {
	background: var(--color-orange);
	color: white;
	box-shadow: var(--shadow-cta);
}
.btn--primary:hover {
	background: var(--color-orange-dark);
	box-shadow: 0 8px 24px rgba(255, 107, 44, 0.40);
}

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

.btn--dark-outline {
	background: transparent;
	color: white;
	border-color: rgba(255, 255, 255, 0.25);
}
.btn--dark-outline:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.45);
}

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

.btn__icon--play {
	background: var(--color-orange);
	color: white;
	border-radius: 50%;
	width: 22px;
	height: 22px;
	padding: 4px;
}

/* --------------------------------------------------------------------------
   4. Header / Nav
   -------------------------------------------------------------------------- */
.site-header {
	background: white;
	padding: 20px 0;
	position: sticky;
	top: 0;
	z-index: 50;
	border-bottom: 1px solid transparent;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.site-header.is-scrolled {
	border-bottom-color: var(--color-line);
	box-shadow: 0 2px 8px rgba(15, 27, 45, 0.04);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
}

.brand-logo {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
}
.brand-logo__text {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 28px;
	letter-spacing: -0.03em;
	color: var(--color-navy);
}
.brand-logo__badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: var(--color-orange);
	color: white;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 13px;
	padding: 4px 10px;
	border-radius: var(--radius-sm);
	letter-spacing: 0.02em;
}
.brand-logo__badge--sm {
	font-size: 9px;
	padding: 2px 6px;
}
.brand-logo__sparkle {
	display: inline-flex;
	width: 12px;
	height: 12px;
}
.brand-logo__sparkle svg { width: 100%; height: 100%; }

.site-nav__menu {
	display: flex;
	gap: 32px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.site-nav__menu a {
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 15px;
	color: var(--color-ink);
	text-decoration: none;
	transition: color 0.15s;
}
.site-nav__menu a:hover { color: var(--color-orange); }

.site-nav__toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-sm);
	padding: 8px;
	color: var(--color-ink);
}
.site-nav__toggle-icon { display: inline-flex; width: 22px; height: 22px; }
.site-nav__toggle-icon svg { width: 100%; height: 100%; }
.site-nav__toggle-icon--close { display: none; }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-icon--open { display: none; }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-icon--close { display: inline-flex; }

.site-header__actions {
	display: flex;
	gap: 12px;
	align-items: center;
}

/* --------------------------------------------------------------------------
   5. Badges & Pills
   -------------------------------------------------------------------------- */
.badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: 0.08em;
	padding: 8px 14px;
	border-radius: var(--radius-pill);
	text-transform: uppercase;
}
.badge--soft {
	background: var(--color-orange-tint);
	color: var(--color-orange-dark);
}
.badge__icon {
	display: inline-flex;
	width: 14px;
	height: 14px;
	color: var(--color-orange);
}
.badge__icon svg { width: 100%; height: 100%; }

.pill {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	border-radius: var(--radius-pill);
	font-size: 12px;
	font-weight: 600;
	font-family: var(--font-display);
}
.pill--soft {
	background: var(--color-orange-tint);
	color: var(--color-orange-dark);
}
.pill--success {
	background: var(--color-green-soft);
	color: var(--color-green);
}
.pill--full {
	width: 100%;
	justify-content: center;
}
.pill__icon { display: inline-flex; width: 10px; height: 10px; }
.pill__icon svg { width: 100%; height: 100%; }

/* --------------------------------------------------------------------------
   6. Hero
   -------------------------------------------------------------------------- */
.hero {
	background: linear-gradient(180deg, #ffffff 0%, var(--color-bg-warm) 100%);
	padding: 48px 0 32px;
	position: relative;
	overflow: hidden;
}
.hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 1px 1px, rgba(255, 107, 44, 0.12) 1px, transparent 0);
	background-size: 32px 32px;
	mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
	-webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
	opacity: 0.5;
	pointer-events: none;
}

.hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
	position: relative;
	z-index: 1;
}

.hero__content {
	display: flex;
	flex-direction: column;
	gap: 24px;
	max-width: 560px;
}

.hero__title {
	font-size: clamp(40px, 5vw, 64px);
	font-weight: 800;
	line-height: 1.05;
}

.hero__lede {
	font-size: 17px;
	color: var(--color-ink-soft);
	line-height: 1.55;
	max-width: 480px;
}

/* Feature checklist in hero */
.feature-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.feature-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 15px;
	color: var(--color-ink);
	font-weight: 500;
}
.feature-list__icon {
	display: inline-flex;
	width: 20px;
	height: 20px;
	color: var(--color-orange);
	flex-shrink: 0;
}
.feature-list__icon svg { width: 100%; height: 100%; }

.hero__actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

.hero__trust {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 4px;
}
.avatar-stack {
	display: inline-flex;
}
.avatar-stack__item {
	display: inline-block;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 3px solid white;
	margin-left: -10px;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}
.avatar-stack__item:first-child { margin-left: 0; }
.hero__trust-text {
	font-size: 14px;
	color: var(--color-ink-soft);
	margin: 0;
	line-height: 1.3;
}

/* Hero visual area */
.hero__visual {
	position: relative;
	min-height: 540px;
}

.hero__mascot {
	position: relative;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero__mascot-img {
	max-width: 100%;
	max-height: 540px;
	object-fit: contain;
	position: relative;
	z-index: 1;
}
.hero__mascot-placeholder {
	width: 360px;
	height: 480px;
	background: repeating-linear-gradient(
		45deg,
		var(--color-orange-soft),
		var(--color-orange-soft) 10px,
		var(--color-bg-warm) 10px,
		var(--color-bg-warm) 20px
	);
	border: 2px dashed var(--color-orange);
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-orange-dark);
	font-family: var(--font-display);
	font-weight: 600;
}

/* Floating notification cards */
.floating-card {
	position: absolute;
	display: flex;
	gap: 12px;
	background: white;
	padding: 14px;
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-float);
	z-index: 2;
	width: 240px;
	animation: float 6s var(--ease-out) infinite;
}

@keyframes float {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-6px); }
}

.floating-card--top-left    { top: 4%;   left: -4%;  animation-delay: 0s; }
.floating-card--top-right   { top: 6%;   right: -6%; animation-delay: 1.2s; }
.floating-card--mid-left    { top: 38%;  left: -8%;  animation-delay: 2.4s; width: 260px; }
.floating-card--mid-right   { top: 36%;  right: -8%; animation-delay: 0.6s; }
.floating-card--bottom-right{ top: 64%;  right: -4%; animation-delay: 1.8s; }

.floating-card__icon {
	width: 38px;
	height: 38px;
	flex-shrink: 0;
	border-radius: var(--radius-sm);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.floating-card__icon svg { width: 20px; height: 20px; }
.floating-card__icon--blue   { background: var(--color-blue-soft); color: var(--color-blue); }
.floating-card__icon--orange { background: var(--color-orange-tint); color: var(--color-orange); }
.floating-card__icon--purple { background: var(--color-purple-soft); color: var(--color-purple); }
.floating-card__icon--cloud  { background: var(--color-blue-soft); color: var(--color-cloud-blue); }

.floating-card__body { flex: 1; min-width: 0; }
.floating-card__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 13px;
	color: var(--color-navy);
	margin-bottom: 4px;
}
.floating-card__meta {
	font-size: 11px;
	color: var(--color-ink-soft);
	line-height: 1.35;
}
.floating-card__meta strong { color: var(--color-ink); font-weight: 600; }
.floating-card__text {
	font-size: 11px;
	color: var(--color-ink-soft);
	margin: 6px 0;
	line-height: 1.45;
}

/* Stats strip */
.stats-strip {
	margin-top: 24px;
	background: white;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: 20px 32px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	box-shadow: var(--shadow-card);
	position: relative;
	z-index: 2;
}
.stat {
	display: flex;
	align-items: center;
	gap: 12px;
}
.stat__icon {
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-orange);
	flex-shrink: 0;
}
.stat__icon svg { width: 28px; height: 28px; }
.stat__value {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 22px;
	color: var(--color-orange);
	line-height: 1;
}
.stat__label {
	font-size: 13px;
	color: var(--color-ink-soft);
	margin-top: 2px;
}

/* --------------------------------------------------------------------------
   7. How It Works
   -------------------------------------------------------------------------- */
.how-it-works {
	padding: 32px 0;
}
.how-it-works__inner {
	background: var(--color-bg-soft);
	border-radius: var(--radius-xl);
	padding: 40px;
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 40px;
	align-items: center;
}

.how-it-works__title {
	font-size: 28px;
	line-height: 1.15;
	margin-bottom: 8px;
}
.how-it-works__lede {
	font-size: 14px;
	color: var(--color-ink-soft);
}

.how-it-works__steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 12px;
	align-items: start;
}

.step {
	position: relative;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}
.step__icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: white;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--shadow-card);
	color: var(--color-blue);
}
.step__icon svg { width: 26px; height: 26px; }
.step__icon--blue   { color: var(--color-blue); }
.step__icon--green  { color: var(--color-green); }
.step__icon--orange { color: var(--color-orange); }

.step__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 14px;
	color: var(--color-navy);
	margin: 8px 0 0;
}
.step__desc {
	font-size: 12px;
	color: var(--color-ink-soft);
	line-height: 1.45;
}
.step__arrow {
	position: absolute;
	top: 22px;
	right: -16px;
	color: var(--color-line);
	width: 24px;
	height: 24px;
	display: inline-flex;
}
.step__arrow svg { width: 100%; height: 100%; }

/* --------------------------------------------------------------------------
   8. Workspace section
   -------------------------------------------------------------------------- */
.workspace {
	padding: 16px 0 32px;
}
.workspace__grid {
	display: grid;
	grid-template-columns: 240px 1fr 240px;
	gap: 24px;
	align-items: stretch;
}
.workspace__intro,
.workspace__handles {
	background: white;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.workspace__handles {
	background: var(--color-bg-warm);
	border-color: var(--color-orange-tint);
	position: relative;
	overflow: hidden;
}

.workspace__title,
.workspace__handles-title {
	font-size: 22px;
	line-height: 1.2;
}
.workspace__lede {
	font-size: 14px;
	color: var(--color-ink-soft);
}

.bullet-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.bullet-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--color-ink);
}
.bullet-list__icon {
	display: inline-flex;
	width: 18px;
	height: 18px;
	color: var(--color-orange);
	flex-shrink: 0;
}
.bullet-list__icon svg { width: 100%; height: 100%; }

.bullet-list--accent .bullet-list__icon { color: var(--color-orange); }

/* App mock */
.workspace__app {
	background: white;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-card);
}
.app-mock {
	display: grid;
	grid-template-columns: 120px 200px 1fr 180px;
	min-height: 340px;
	font-size: 12px;
}

.app-mock__sidebar {
	background: var(--color-bg-soft);
	border-right: 1px solid var(--color-line);
	padding: 14px 10px;
}
.app-mock__brand {
	display: flex;
	align-items: center;
	gap: 4px;
	margin-bottom: 14px;
	padding: 0 4px;
}
.app-mock__brand .brand-logo__text { font-size: 16px; }

.app-mock__nav {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.app-mock__nav-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 7px 10px;
	border-radius: var(--radius-sm);
	color: var(--color-ink-soft);
	font-weight: 500;
	text-decoration: none;
	transition: background 0.15s;
}
.app-mock__nav-item svg { width: 14px; height: 14px; }
.app-mock__nav-item:hover { background: rgba(15, 27, 45, 0.04); }
.app-mock__nav-item.is-active {
	background: var(--color-orange-tint);
	color: var(--color-orange-dark);
}

.app-mock__inbox {
	border-right: 1px solid var(--color-line);
	padding: 14px 10px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.app-mock__inbox-header {
	display: flex;
	align-items: center;
	gap: 6px;
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-orange);
	padding: 0 4px;
}
.app-mock__plus { display: inline-flex; width: 14px; height: 14px; }
.app-mock__plus svg { width: 100%; height: 100%; }
.app-mock__tabs {
	display: flex;
	gap: 12px;
	padding: 0 4px;
	border-bottom: 1px solid var(--color-line);
	padding-bottom: 6px;
}
.app-mock__tab {
	font-size: 11px;
	font-weight: 600;
	color: var(--color-muted);
	padding-bottom: 2px;
}
.app-mock__tab.is-active {
	color: var(--color-orange);
	border-bottom: 2px solid var(--color-orange);
}
.app-mock__messages {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.app-mock__message {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 7px 6px;
	border-radius: var(--radius-sm);
	cursor: pointer;
}
.app-mock__message.is-active { background: var(--color-bg-soft); }
.app-mock__avatar {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	flex-shrink: 0;
}
.app-mock__avatar--icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue);
}
.app-mock__avatar--icon svg { width: 12px; height: 12px; }
.app-mock__message-body { flex: 1; min-width: 0; }
.app-mock__message-name {
	font-weight: 600;
	color: var(--color-navy);
	font-size: 11px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.app-mock__message-sub {
	font-size: 10px;
	color: var(--color-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.app-mock__time {
	font-size: 9px;
	color: var(--color-muted);
}

.app-mock__reader {
	padding: 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	border-right: 1px solid var(--color-line);
}
.app-mock__reader-name {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-navy);
	font-size: 13px;
}
.app-mock__reader-sub {
	font-size: 10px;
	color: var(--color-muted);
}
.app-mock__reader-body p {
	font-size: 11px;
	color: var(--color-ink);
	margin: 0 0 6px;
}
.app-mock__reader-fred { margin-top: 4px; }
.app-mock__reader-footer {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: auto;
	padding-top: 8px;
}
.app-mock__icon-btn {
	width: 26px;
	height: 26px;
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-line);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-muted);
}
.app-mock__icon-btn svg { width: 12px; height: 12px; }

.app-mock__panel {
	background: var(--color-bg-soft);
	padding: 14px 10px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.app-mock__panel-header {
	display: flex;
	align-items: center;
	gap: 6px;
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-orange);
	font-size: 12px;
	margin-bottom: 4px;
}
.app-mock__panel-icon { display: inline-flex; width: 12px; height: 12px; }
.app-mock__panel-icon svg { width: 100%; height: 100%; }

.app-mock__opp {
	background: white;
	padding: 10px;
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-line);
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.app-mock__opp-title {
	font-weight: 700;
	color: var(--color-navy);
	font-size: 11px;
}
.app-mock__opp-meta {
	font-size: 10px;
	color: var(--color-muted);
}
.app-mock__opp-value {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-navy);
	font-size: 13px;
}
.app-mock__view-all {
	text-align: center;
	color: var(--color-orange);
	font-weight: 600;
	font-size: 11px;
	padding: 6px;
	background: white;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-sm);
	margin-top: 4px;
	text-decoration: none;
}

/* --------------------------------------------------------------------------
   9. CTA banner
   -------------------------------------------------------------------------- */
.cta-banner {
	padding: 16px 0 64px;
}
.cta-banner__inner {
	background: var(--color-navy);
	background-image:
		radial-gradient(circle at 90% 50%, rgba(255, 107, 44, 0.16) 0%, transparent 50%),
		radial-gradient(circle at 10% 100%, rgba(45, 127, 232, 0.10) 0%, transparent 50%);
	color: white;
	border-radius: var(--radius-xl);
	padding: 32px 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
}
.cta-banner__title {
	color: white;
	font-size: 28px;
	margin-bottom: 8px;
}
.cta-banner__lede {
	color: rgba(255, 255, 255, 0.75);
	font-size: 14px;
	line-height: 1.5;
	margin: 0;
}
.cta-banner__actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

/* --------------------------------------------------------------------------
   10. Footer
   -------------------------------------------------------------------------- */
.site-footer {
	background: var(--color-bg-soft);
	border-top: 1px solid var(--color-line);
	padding: 56px 0 0;
}
.site-footer__inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: start;
	padding-bottom: 32px;
}
.site-footer__brand .brand-logo { margin-bottom: 12px; }
.site-footer__tagline {
	color: var(--color-ink-soft);
	font-size: 14px;
	max-width: 360px;
}
.site-footer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
}
.site-footer__menu a {
	color: var(--color-ink-soft);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
}
.site-footer__menu a:hover { color: var(--color-orange); }

.site-footer__bottom {
	border-top: 1px solid var(--color-line);
	padding: 20px 0;
}
.site-footer__copyright {
	font-size: 13px;
	color: var(--color-muted);
	margin: 0;
}

/* --------------------------------------------------------------------------
   11. Standard pages (single, page, 404)
   -------------------------------------------------------------------------- */
.site-main {
	min-height: 40vh;
}
.page-content,
.single-post,
.post-card {
	padding: 48px 0;
}
.page-content__title,
.single-post__title,
.post-card__title {
	font-size: clamp(28px, 4vw, 44px);
	margin-bottom: 16px;
}
.single-post__meta {
	color: var(--color-muted);
	font-size: 14px;
	margin-bottom: 24px;
}
.error-404 {
	text-align: center;
	padding: 96px 0;
}
.error-404__title {
	font-size: clamp(72px, 12vw, 140px);
	color: var(--color-orange);
	line-height: 1;
	margin-bottom: 16px;
}
.error-404__lede {
	font-size: 18px;
	color: var(--color-ink-soft);
	margin-bottom: 32px;
}

/* --------------------------------------------------------------------------
   12. Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 1100px) {
	.hero__inner { grid-template-columns: 1fr; gap: 32px; }
	.hero__visual { min-height: 480px; }
	.floating-card--top-left    { left: 0; }
	.floating-card--top-right   { right: 0; }
	.floating-card--mid-left    { left: 0; }
	.floating-card--mid-right   { right: 0; }
	.floating-card--bottom-right{ right: 0; }

	.workspace__grid { grid-template-columns: 1fr; }
	.app-mock { grid-template-columns: 100px 1fr 1fr; }
	.app-mock__panel { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; }
	.app-mock__opp { flex: 1; min-width: 200px; }

	.how-it-works__inner { grid-template-columns: 1fr; gap: 32px; }
	.how-it-works__steps { grid-template-columns: repeat(3, 1fr); gap: 32px 16px; }
	.step__arrow { display: none; }
}

@media (max-width: 768px) {
	.site-header { padding: 14px 0; }
	.site-nav { position: static; }
	.site-nav__toggle { display: inline-flex; }
	.site-nav__menu {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: white;
		flex-direction: column;
		padding: 16px var(--container-pad);
		gap: 8px;
		border-top: 1px solid var(--color-line);
		box-shadow: 0 4px 12px rgba(15, 27, 45, 0.06);
	}
	.site-nav__menu.is-open { display: flex; }
	.site-nav__menu a { padding: 10px 0; display: block; }
	.site-header__actions .btn--ghost { display: none; }

	.hero { padding: 32px 0; }
	.hero__title { font-size: 36px; }
	.feature-list { grid-template-columns: 1fr; }

	.floating-card { position: relative; top: auto !important; left: auto !important; right: auto !important; width: 100%; }
	.hero__visual {
		min-height: auto;
		display: grid;
		gap: 12px;
		grid-template-columns: 1fr;
	}
	.hero__mascot-placeholder { width: 100%; height: 280px; }

	.stats-strip { grid-template-columns: 1fr 1fr; padding: 16px; gap: 16px; }
	.how-it-works__inner { padding: 24px; }
	.how-it-works__steps { grid-template-columns: 1fr 1fr; }

	.app-mock { grid-template-columns: 1fr; }
	.app-mock__sidebar { display: none; }

	.cta-banner__inner { padding: 24px; flex-direction: column; align-items: flex-start; }
	.cta-banner__title { font-size: 22px; }

	.site-footer__inner { grid-template-columns: 1fr; }
}
