/* ============================================================
   ShipEasy — marketing site styles
   ============================================================ */

:root {
	/* Brand */
	--color-bg: #f8f7f5;
	--color-surface: #ffffff;
	--color-text: #0f1a17;
	--color-text-muted: #4a5853;
	--color-text-soft: #6b7975;

	--color-accent: #0a5c50;
	--color-accent-hover: #084a41;
	--color-accent-soft: #e6f0ee;
	--color-accent-softer: #f3f9f7;

	--color-border: #e4e2dd;
	--color-border-soft: #efece7;

	--color-success: #1f6b1f;
	--color-danger: #b00020;
	--color-warning: #8a5a00;

	/* Type */
	--font-sans: "DM Sans", system-ui, -apple-system, sans-serif;
	--font-display: "Outfit", system-ui, -apple-system, sans-serif;

	/* Spacing */
	--space-2xs: 0.25rem;
	--space-xs: 0.5rem;
	--space-sm: 1rem;
	--space-md: 1.5rem;
	--space-lg: 2rem;
	--space-xl: 3rem;
	--space-2xl: 4rem;
	--space-3xl: 5rem;
	--space-4xl: 7rem;

	/* Other */
	--radius-sm: 8px;
	--radius: 14px;
	--radius-lg: 22px;
	--radius-xl: 28px;
	--radius-full: 9999px;

	--shadow-xs: 0 1px 2px rgba(15, 26, 23, 0.04);
	--shadow: 0 2px 16px rgba(15, 26, 23, 0.05);
	--shadow-card: 0 6px 28px rgba(15, 26, 23, 0.07);
	--shadow-soft: 0 14px 48px rgba(10, 92, 80, 0.12);
	--shadow-lift: 0 22px 64px rgba(10, 92, 80, 0.18);
}

/* ===== Reset / base =========================================== */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--color-text);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4 { margin: 0; }

ul, ol { margin: 0; padding: 0; list-style: none; }

.skip-link {
	position: absolute;
	left: -1000px;
	top: -1000px;
	background: var(--color-accent);
	color: #fff;
	padding: var(--space-sm) var(--space-md);
	border-radius: 0 0 var(--radius) 0;
	font-weight: 600;
	z-index: 100;
}
.skip-link:focus { left: 0; top: 0; text-decoration: none; }

/* ===== Header ================================================= */
.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	background: rgba(255, 255, 255, 0.78);
	backdrop-filter: saturate(1.4) blur(14px);
	-webkit-backdrop-filter: saturate(1.4) blur(14px);
	border-bottom: 1px solid var(--color-border-soft);
}
.header-inner {
	max-width: 76rem;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: 0.875rem var(--space-lg);
}
.logo-link {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	color: var(--color-text);
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: -0.01em;
}
.logo-link:hover { text-decoration: none; opacity: 0.88; }
.logo-mark { height: 32px; width: auto; border-radius: 6px; }
.logo-wordmark { font-size: 1.0625rem; }

.nav { display: none; gap: var(--space-lg); }
@media (min-width: 820px) { .nav { display: flex; } }
.nav a {
	color: var(--color-text-muted);
	font-weight: 500;
	font-size: 0.9375rem;
	transition: color 0.15s ease;
}
.nav a:hover { color: var(--color-text); text-decoration: none; }

.header-actions { display: flex; align-items: center; gap: var(--space-sm); }

/* ===== Buttons ================================================ */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.25rem;
	font-family: var(--font-sans);
	font-size: 0.9375rem;
	font-weight: 600;
	border-radius: var(--radius);
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: transform 0.18s ease, box-shadow 0.18s ease,
		background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
	text-decoration: none;
	line-height: 1.2;
	white-space: nowrap;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-sm { padding: 0.5rem 0.9375rem; font-size: 0.875rem; }
.btn-lg { padding: 1rem 1.5rem; font-size: 1.0625rem; }
.btn-block { display: flex; width: 100%; }
.btn-primary {
	background: var(--color-accent);
	color: #fff;
	box-shadow: var(--shadow-soft);
}
.btn-primary:hover { background: var(--color-accent-hover); box-shadow: var(--shadow-lift); }
.btn-secondary {
	background: var(--color-surface);
	color: var(--color-accent);
	border-color: var(--color-accent);
}
.btn-secondary:hover { background: var(--color-accent-softer); border-color: var(--color-accent-hover); }
.btn-icon { width: 18px; height: 18px; flex: 0 0 18px; }

/* ===== Section primitives ===================================== */
.eyebrow {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-accent);
	background: var(--color-accent-soft);
	padding: 0.375rem 0.875rem;
	border-radius: var(--radius-full);
	margin-bottom: var(--space-md);
}
.eyebrow-center {
	display: block;
	text-align: center;
	max-width: max-content;
	margin-left: auto;
	margin-right: auto;
}

.section { padding: var(--space-3xl) var(--space-lg); }
.section-alt { background: var(--color-surface); }

.container { max-width: 64rem; margin: 0 auto; }
.container-narrow { max-width: 44rem; margin: 0 auto; }
.container-wide { max-width: 76rem; margin: 0 auto; }

.section-title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	text-align: center;
	letter-spacing: -0.025em;
	color: var(--color-text);
	line-height: 1.15;
	margin: 0 0 var(--space-md);
}
.section-lead {
	text-align: center;
	color: var(--color-text-muted);
	font-size: 1.125rem;
	margin: 0 auto var(--space-2xl);
	max-width: 36rem;
	line-height: 1.7;
}

/* ===== Hero =================================================== */
.hero {
	position: relative;
	overflow: hidden;
	padding: var(--space-4xl) var(--space-lg) var(--space-3xl);
	min-height: 76vh;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero-content { position: relative; z-index: 1; max-width: 44rem; text-align: center; }
.hero-title {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: clamp(2.25rem, 6vw, 4rem);
	line-height: 1.05;
	letter-spacing: -0.035em;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
}
.hero-desc {
	font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
	color: var(--color-text-muted);
	margin: 0 auto var(--space-xl);
	max-width: 38rem;
	line-height: 1.6;
}
.hero-actions {
	display: flex;
	gap: var(--space-sm);
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: var(--space-xl);
}
.hero-trust {
	display: flex;
	gap: var(--space-lg);
	justify-content: center;
	flex-wrap: wrap;
	color: var(--color-text-muted);
	font-size: 0.9375rem;
}
.hero-trust li { display: inline-flex; align-items: center; gap: 0.4375rem; }
.check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--color-accent-soft);
	color: var(--color-accent);
	font-size: 0.7rem;
	font-weight: 700;
	flex: 0 0 18px;
}

.hero-visual { position: absolute; inset: 0; pointer-events: none; }
.blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.55; }
.blob-1 { width: 460px; height: 460px; background: var(--color-accent-soft); top: -8%; left: 50%; transform: translateX(-50%); }
.blob-2 { width: 320px; height: 320px; background: rgba(10, 92, 80, 0.1); bottom: 5%; left: 8%; }
.blob-3 { width: 260px; height: 260px; background: rgba(10, 92, 80, 0.06); bottom: 12%; right: 8%; }

/* ===== Problem section ======================================== */
.section-problem { padding-top: var(--space-2xl); }
.problem-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-lg);
	margin-top: var(--space-xl);
}
@media (min-width: 700px) { .problem-grid { grid-template-columns: 1fr 1fr; } }

.problem-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-xs);
}
.problem-card h3 {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: var(--space-md);
	color: var(--color-text);
}
.problem-card ul { display: flex; flex-direction: column; gap: 0.625rem; }
.problem-card li {
	color: var(--color-text-muted);
	font-size: 0.9375rem;
	line-height: 1.55;
	padding-left: 1.25rem;
	position: relative;
}
.problem-card li::before { content: "—"; position: absolute; left: 0; color: var(--color-border); }
.problem-card-good { border-color: var(--color-accent); box-shadow: var(--shadow-soft); }
.problem-card-good li::before { content: "✓"; color: var(--color-accent); font-weight: 700; }
.problem-x, .problem-check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: var(--radius-full);
	font-weight: 700;
	font-size: 1rem;
	margin-bottom: var(--space-md);
}
.problem-x { background: #fde7e9; color: var(--color-danger); }
.problem-check { background: var(--color-accent-soft); color: var(--color-accent); }

/* ===== Steps ================================================== */
.steps { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(3, 1fr); } }

.step {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-card);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
	position: relative;
}
.step:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); border-color: var(--color-accent-soft); }
.step-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--color-accent);
	background: var(--color-accent-soft);
	border-radius: var(--radius-full);
	margin-bottom: var(--space-md);
}
.step h3 {
	font-family: var(--font-display);
	font-size: 1.1875rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}
.step p { color: var(--color-text-muted); font-size: 0.9375rem; line-height: 1.6; }
.step strong { color: var(--color-text); font-weight: 600; }

/* ===== Features grid ========================================== */
.features-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
@media (min-width: 640px) { .features-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 960px) { .features-grid { grid-template-columns: repeat(3, 1fr); } }

.feature-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-xs);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.feature-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); border-color: var(--color-accent-soft); }
.feature-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	color: var(--color-accent);
	background: var(--color-accent-soft);
	border-radius: var(--radius);
	margin-bottom: var(--space-md);
}
.feature-icon svg { width: 22px; height: 22px; }
.feature-card h3 {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}
.feature-card p { color: var(--color-text-muted); font-size: 0.9375rem; line-height: 1.6; }

/* ===== Carriers =============================================== */
.carriers-list { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 720px) { .carriers-list { grid-template-columns: repeat(3, 1fr); } }

.carrier-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: var(--space-lg);
	box-shadow: var(--shadow-xs);
}
.carrier-name {
	font-family: var(--font-display);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--color-accent);
	margin-bottom: 0.375rem;
	letter-spacing: -0.01em;
}
.carrier-desc { color: var(--color-text-muted); font-size: 0.875rem; line-height: 1.55; }
.carriers-footnote { text-align: center; color: var(--color-text-soft); font-size: 0.875rem; margin-top: var(--space-lg); }

/* ===== Pricing ================================================ */
.pricing-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xl);
	padding: var(--space-xl);
	box-shadow: var(--shadow-soft);
	max-width: 30rem;
	margin: 0 auto;
}
.pricing-line {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border-soft);
	flex-wrap: wrap;
}
.pricing-line:first-child { padding-top: 0; }
.pricing-line:last-of-type { border-bottom: none; }
.pricing-label { color: var(--color-text-muted); font-size: 0.9375rem; }
.pricing-value {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.125rem;
	color: var(--color-text);
}
.pricing-note { color: var(--color-text-muted); font-size: 0.875rem; line-height: 1.6; margin: var(--space-md) 0 var(--space-lg); }
.pricing-note strong { color: var(--color-text); }

/* ===== FAQ ==================================================== */
.faq { display: flex; flex-direction: column; gap: var(--space-sm); }

.faq-item {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	overflow: hidden;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.faq-item[open] { border-color: var(--color-accent-soft); box-shadow: var(--shadow); }

.faq-item summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-md) var(--space-lg);
	cursor: pointer;
	list-style: none;
	user-select: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-q {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 1rem;
	color: var(--color-text);
	line-height: 1.4;
}
.faq-icon {
	flex: 0 0 1.5rem;
	font-size: 1.25rem;
	color: var(--color-accent);
	transition: transform 0.2s ease;
	font-weight: 400;
	line-height: 1;
}
.faq-item[open] .faq-icon { transform: rotate(45deg); }

.faq-a { padding: 0 var(--space-lg) var(--space-md); color: var(--color-text-muted); font-size: 0.9375rem; line-height: 1.65; }
.faq-a p { margin: 0; }
.faq-a p + p { margin-top: var(--space-sm); }
.faq-a a { color: var(--color-accent); font-weight: 500; }

/* ===== CTA ==================================================== */
.section-cta {
	background: linear-gradient(180deg, var(--color-accent-soft) 0%, var(--color-bg) 100%);
	padding-top: var(--space-4xl);
	padding-bottom: var(--space-4xl);
}
.section-cta .section-title { font-size: clamp(2rem, 4.5vw, 2.75rem); }
.cta-actions {
	display: flex;
	gap: var(--space-sm);
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: var(--space-lg);
}
.cta-footnote { text-align: center; color: var(--color-text-soft); font-size: 0.875rem; margin-top: var(--space-lg); }
.cta-footnote a { color: var(--color-accent); font-weight: 500; }

/* ===== Footer ================================================= */
.site-footer {
	background: var(--color-surface);
	border-top: 1px solid var(--color-border);
	padding: var(--space-2xl) var(--space-lg) var(--space-lg);
}
.footer-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	max-width: 76rem;
	margin: 0 auto;
	padding-bottom: var(--space-lg);
}
@media (min-width: 720px) {
	.footer-inner { grid-template-columns: 1fr 2fr; gap: var(--space-2xl); }
}
.footer-brand { max-width: 22rem; }
.footer-brand .logo-link { margin-bottom: var(--space-sm); }
.footer-tagline { color: var(--color-text-muted); font-size: 0.9375rem; line-height: 1.6; margin: 0; }

.footer-cols {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
}
@media (max-width: 540px) { .footer-cols { grid-template-columns: repeat(2, 1fr); } }

.footer-col h4 {
	font-family: var(--font-sans);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}
.footer-col a {
	display: block;
	color: var(--color-text-muted);
	font-size: 0.9375rem;
	padding: 0.1875rem 0;
}
.footer-col a:hover { color: var(--color-text); text-decoration: none; }

.footer-bottom {
	max-width: 76rem;
	margin: 0 auto;
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border-soft);
	display: flex;
	justify-content: space-between;
	gap: var(--space-md);
	flex-wrap: wrap;
}
.footer-copy { margin: 0; color: var(--color-text-soft); font-size: 0.8125rem; }

/* ===== Legal pages ============================================ */
.legal-main {
	padding: var(--space-2xl) var(--space-lg) var(--space-3xl);
	background: var(--color-surface);
}
.legal-main .container-narrow { max-width: 44rem; }

.legal-title {
	font-family: var(--font-display);
	font-size: clamp(1.875rem, 4vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	margin: 0 0 var(--space-xs);
	line-height: 1.15;
}
.legal-meta {
	color: var(--color-text-soft);
	font-size: 0.9375rem;
	margin: 0 0 var(--space-2xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border-soft);
}
.legal-meta strong { color: var(--color-text-muted); font-weight: 500; }

.legal-section { margin-bottom: var(--space-xl); }
.legal-section h2 {
	font-family: var(--font-display);
	font-size: 1.375rem;
	font-weight: 600;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	letter-spacing: -0.01em;
	line-height: 1.3;
}
.legal-section h3 {
	font-family: var(--font-sans);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--color-text);
	margin: var(--space-lg) 0 var(--space-sm);
}
.legal-section p { margin: 0 0 var(--space-md); color: var(--color-text); line-height: 1.7; }
.legal-section p:last-child { margin-bottom: 0; }
.legal-section ul { margin: 0 0 var(--space-md); padding-left: 1.5rem; color: var(--color-text); line-height: 1.7; list-style: disc; }
.legal-section li { margin-bottom: 0.375rem; }
.legal-section li:last-child { margin-bottom: 0; }
.legal-section a { color: var(--color-accent); }
.legal-section a:hover { text-decoration: underline; }

.legal-section table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 var(--space-md);
	font-size: 0.9375rem;
}
.legal-section th,
.legal-section td {
	padding: 0.625rem 0.875rem;
	border: 1px solid var(--color-border);
	text-align: left;
	vertical-align: top;
}
.legal-section th { background: var(--color-bg); font-weight: 600; }

/* ===== Responsive shrink ===================================== */
@media (max-width: 600px) {
	.section { padding: var(--space-2xl) var(--space-md); }
	.hero { padding: var(--space-2xl) var(--space-md) var(--space-xl); min-height: auto; }
	.btn-lg { padding: 0.875rem 1.25rem; font-size: 1rem; }
	.header-inner { padding: 0.625rem var(--space-md); }
	.site-footer { padding: var(--space-xl) var(--space-md) var(--space-md); }
}

@media (prefers-reduced-motion: reduce) {
	* {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
