:root {
	--app-bg: #f5efe6;
	--app-surface: #fffaf4;
	--app-surface-strong: #ffffff;
	--app-text: #221b17;
	--app-muted: #6c5d53;
	--app-accent: #d2613c;
	--app-accent-dark: #9f4326;
	--app-line: rgba(34, 27, 23, 0.08);
	--app-shadow: 0 20px 60px rgba(73, 44, 31, 0.12);
	--app-radius-lg: 28px;
	--app-radius-md: 20px;
	--app-shell: min(1160px, calc(100vw - 32px));
}

body {
	background:
		radial-gradient(circle at top left, rgba(210, 97, 60, 0.18), transparent 32%),
		linear-gradient(180deg, #fcf6f0 0%, #f6efe6 100%);
	color: var(--app-text);
}

.app-shell {
	width: var(--app-shell);
	margin: 0 auto;
}

.app-homepage section,
.inner-page section {
	padding: 88px 0;
}

.eyebrow {
	display: inline-block;
	margin-bottom: 16px;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--app-accent);
}

.hero-section {
	padding-top: 112px;
}

.hero-grid,
.split-layout {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 32px;
	align-items: center;
}

.hero-copy h1,
.inner-hero h1,
.section-heading h2,
.cta-panel h2 {
	margin: 0 0 18px;
	font-size: clamp(2.4rem, 5vw, 4.7rem);
	line-height: 0.96;
	letter-spacing: -0.04em;
}

.hero-copy p,
.inner-hero p,
.section-heading p,
.testimonial-copy p,
.content-card,
.info-card,
.showcase-card p,
.timeline-card p,
.quote-card p,
.brand-strip p {
	font-size: 1.03rem;
	line-height: 1.8;
	color: var(--app-muted);
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 28px;
}

.hero-mini-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	margin-top: 28px;
}

.hero-mini-stats div {
	padding: 16px 18px;
	border: 1px solid var(--app-line);
	border-radius: 20px;
	background: rgba(255, 255, 255, 0.56);
}

.hero-mini-stats strong {
	display: block;
	font-size: 1rem;
}

.hero-mini-stats span {
	display: block;
	margin-top: 6px;
	color: var(--app-muted);
	font-size: 0.92rem;
	line-height: 1.5;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 22px;
	border-radius: 999px;
	font-weight: 700;
	text-decoration: none;
	transition: transform 180ms ease, background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}

.button:hover {
	transform: translateY(-2px);
}

.button-primary {
	background: var(--app-accent);
	color: #fff;
}

.button-primary:hover {
	background: var(--app-accent-dark);
	color: #fff;
}

.button-secondary {
	border: 1px solid rgba(34, 27, 23, 0.14);
	color: var(--app-text);
	background: rgba(255, 255, 255, 0.6);
}

.glass-card,
.showcase-card,
.timeline-card,
.content-card,
.info-card,
.cta-panel,
.app-media-card,
.store-banner {
	border: 1px solid var(--app-line);
	border-radius: var(--app-radius-lg);
	background: rgba(255, 255, 255, 0.72);
	backdrop-filter: blur(16px);
	box-shadow: var(--app-shadow);
}

.hero-card,
.content-card,
.info-card,
.cta-panel,
.app-media-card,
.store-banner {
	padding: 34px;
}

.hero-stack {
	position: relative;
	display: grid;
	gap: 18px;
}

.hero-app-card {
	display: block;
	padding: 18px;
	text-decoration: none;
	color: inherit;
}

.hero-app-card img {
	display: block;
	width: 100%;
	height: 280px;
	object-fit: cover;
	border-radius: 22px;
	margin-top: 14px;
}

.hero-app-copy {
	padding: 16px 6px 6px;
}

.hero-app-copy h2 {
	margin-bottom: 8px;
}

.hero-float-card {
	max-width: 270px;
	padding: 20px 22px;
	margin-left: auto;
}

.showcase-media {
	margin-bottom: 18px;
	overflow: hidden;
	border-radius: 18px;
	border: 1px solid var(--app-line);
	background: #fff;
}

.showcase-media img,
.app-banner img,
.store-badge img {
	display: block;
	width: 100%;
	height: auto;
}

.app-banner {
	overflow: hidden;
	border-radius: 22px;
	border: 1px solid var(--app-line);
	background: #fff;
}

.app-media-grid {
	display: grid;
	grid-template-columns: 1.35fr 0.9fr;
	gap: 18px;
	align-items: start;
	margin-bottom: 24px;
}

.store-banner {
	display: grid;
	gap: 16px;
	align-content: start;
}

.store-badge {
	display: inline-flex;
	max-width: 240px;
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid var(--app-line);
	background: #fff;
}

.cta-link-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 18px;
}

.hero-card-label,
.card-tag {
	display: inline-flex;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(210, 97, 60, 0.12);
	color: var(--app-accent-dark);
	font-size: 0.82rem;
	font-weight: 700;
}

.hero-card h2,
.showcase-card h3,
.timeline-card h3,
.info-card h2 {
	margin: 18px 0 14px;
	font-size: 1.7rem;
}

.stat-list,
.showcase-card ul,
.info-card ul {
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
}

.stat-list li,
.showcase-card li,
.info-card li {
	display: flex;
	gap: 12px;
	padding: 12px 0;
	border-top: 1px solid var(--app-line);
}

.stat-list strong {
	min-width: 56px;
	font-size: 1.4rem;
	color: var(--app-text);
}

.brand-strip {
	padding: 28px 0;
}

.brand-strip .app-shell {
	padding: 18px 26px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.65);
	border: 1px solid var(--app-line);
	text-align: center;
}

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

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

.showcase-card {
	padding: 28px;
}

.feature-card-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 10px;
}

.feature-card-top h3 {
	margin: 0;
	font-size: 1.55rem;
}

.feature-media {
	margin-bottom: 20px;
}

.feature-media img {
	width: 100%;
	height: 240px;
	object-fit: cover;
}

.feature-media-icon img {
	object-fit: contain;
	padding: 24px;
	background: linear-gradient(180deg, #fff, #f6efe6);
}

.feature-points {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}

.feature-points span {
	display: inline-flex;
	padding: 10px 14px;
	border-radius: 999px;
	background: rgba(210, 97, 60, 0.1);
	color: var(--app-text);
	font-size: 0.92rem;
	font-weight: 600;
}

.spotlight-section {
	padding-top: 16px;
}

.spotlight-panel {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 28px 30px;
	border: 1px solid var(--app-line);
	border-radius: 28px;
	background: rgba(255, 255, 255, 0.58);
	box-shadow: var(--app-shadow);
}

.spotlight-panel h2 {
	margin: 0;
	font-size: clamp(1.8rem, 3vw, 2.7rem);
	line-height: 1.05;
}

.spotlight-panel p {
	max-width: 360px;
	margin: 0;
}

.knowledge-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 24px;
	align-items: start;
}

.knowledge-links {
	display: grid;
	gap: 18px;
}

.knowledge-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 24px 26px;
	border: 1px solid var(--app-line);
	border-radius: 24px;
	background: rgba(255, 255, 255, 0.68);
	box-shadow: var(--app-shadow);
	text-decoration: none;
	transition: transform 180ms ease, border-color 180ms ease;
}

.knowledge-link:hover {
	transform: translateY(-2px);
	border-color: rgba(210, 97, 60, 0.4);
}

.knowledge-link strong {
	font-size: 1.08rem;
}

.knowledge-link span {
	color: var(--app-accent-dark);
	font-weight: 700;
}

.cta-panel {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.inner-hero {
	padding-top: 96px;
}

.content-card > :first-child {
	margin-top: 0;
}

.content-card > :last-child {
	margin-bottom: 0;
}

.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 600ms ease, transform 600ms ease;
}

.reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (max-width: 920px) {
	.hero-grid,
	.split-layout,
	.feature-grid,
	.cta-panel,
	.app-media-grid,
	.knowledge-grid,
	.spotlight-panel,
	.hero-mini-stats {
		grid-template-columns: 1fr;
	}

	.cta-panel {
		display: grid;
	}

	.spotlight-panel {
		display: grid;
	}

	.hero-copy h1,
	.inner-hero h1,
	.section-heading h2,
	.cta-panel h2 {
		font-size: clamp(2.2rem, 9vw, 3.4rem);
	}
}

@media (max-width: 640px) {
	.app-homepage section,
	.inner-page section {
		padding: 68px 0;
	}

	.hero-card,
	.content-card,
	.info-card,
	.showcase-card,
	.cta-panel {
		padding: 24px;
	}

	.brand-strip .app-shell {
		border-radius: 28px;
	}

	.hero-app-card img,
	.feature-media img {
		height: auto;
	}
}
