/**
 * Coffee Trade — Template parts & static pages (handoff §7.2–§7.7)
 * ----------------------------------------------------------------------------
 * Loaded globally (the parts appear on the homepage, machine archives/singles,
 * the store landing and every static page). Owns:
 *
 *   - shared layout primitives (.ctc-container/.ctc-section/.ctc-overline/
 *     .ctc-section-head) for use OUTSIDE the front page's .ctc-home scope;
 *   - reusable parts: .ctc-band (+ variants), .ctc-process, .ctc-props,
 *     .ctc-info, .ctc-tile, .ctc-faq, .ctc-page-hero;
 *   - machine-archive landing bits (.ctc-archive-cta / .ctc-archive-faq);
 *   - the store landing and the segment/static page scaffolding.
 */

/* ===========================================================================
 * Shared primitives (unscoped — mirror the .ctc-home values)
 * ======================================================================== */
.ctc-container {
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.ctc-container--wide {
	max-width: 1380px;
}

.ctc-section {
	padding-block: calc(var(--ctc-section-pad) / 2);
}

.ctc-overline {
	display: inline-block;
	font-size: var(--ctc-text-overline);
	font-weight: var(--ctc-weight-ui);
	letter-spacing: var(--ctc-track-overline);
	text-transform: uppercase;
	color: var(--ctc-text-muted);
}

.ctc-section-head {
	margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.ctc-section-head .ctc-overline {
	display: block;
	margin-bottom: var(--ctc-space-3);
	color: var(--ctc-text-faint);
}

.ctc-section-head__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: var(--ctc-text-title);
	letter-spacing: var(--ctc-track-display);
	text-transform: uppercase;
	line-height: 1.1;
	color: var(--ctc-text);
	margin: 0;
}

.ctc-section-head--split {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--ctc-space-5);
	flex-wrap: wrap;
}

/* A quiet text-link voice inverted for dark grounds. */
.ctc-text-link--inverse {
	color: var(--ctc-cream);
}

.ctc-text-link--inverse:hover,
.ctc-text-link--inverse:focus {
	color: var(--ctc-bronze);
}

/* ===========================================================================
 * Dark bands (.ctc-band) — shared by homepage §4/§7/§12 and closing advisories
 * ======================================================================== */
.ctc-band {
	background: var(--ctc-espresso);
	color: var(--ctc-cream);
	padding-block: var(--ctc-section-pad);
	text-align: center;
}

.ctc-band--steps,
.ctc-band--logos,
.ctc-band--advisory {
	background: var(--ctc-espresso);
}

/* Warm walnut for the closing advisory band, to vary the rhythm. */
.ctc-band--advisory {
	background: var(--ctc-walnut);
}

.ctc-band--intro {
	padding-block: clamp(3rem, 2rem + 4vw, 5rem) clamp(2rem, 1.5rem + 2vw, 3rem);
}

.ctc-band__inner {
	max-width: 760px;
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.ctc-band__overline {
	display: block;
	margin-bottom: var(--ctc-space-3);
	color: var(--ctc-bronze);
}

.ctc-band__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: var(--ctc-text-display);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.1;
	color: var(--ctc-cream);
	margin: 0;
	text-wrap: balance;
}

.ctc-band__title--sm {
	font-size: var(--ctc-text-title);
}

.ctc-band__text {
	margin: var(--ctc-space-4) auto 0;
	max-width: 52ch;
	color: rgba(246, 246, 245, 0.82);
}

.ctc-band__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--ctc-space-3) var(--ctc-space-5);
	margin-top: clamp(1.75rem, 3vw, 2.5rem);
}

/* Primary pill inverts to cream on the dark bands. */
.ctc-band .ctc-btn--primary {
	background: var(--ctc-cream);
	color: var(--ctc-espresso);
	border-color: var(--ctc-cream);
}

.ctc-band .ctc-btn--primary:hover,
.ctc-band .ctc-btn--primary:focus {
	background: transparent;
	color: var(--ctc-cream);
	border-color: var(--ctc-cream);
}

.ctc-band__phone {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2.125rem);
	letter-spacing: 0.05em;
	color: var(--ctc-cream);
	text-decoration: none;
	border-bottom: 1px solid var(--ctc-hairline-on-dark);
	transition: border-color var(--ctc-transition);
}

.ctc-band__phone:hover,
.ctc-band__phone:focus {
	color: var(--ctc-cream);
	border-color: var(--ctc-bronze);
}

/* Inverted ghost pill used on dark bands (homepage §4). */
.ctc-btn--ghost-inverse {
	background: transparent;
	color: var(--ctc-cream);
	border-color: var(--ctc-hairline-on-dark);
}

.ctc-btn--ghost-inverse:hover,
.ctc-btn--ghost-inverse:focus {
	background: var(--ctc-cream);
	color: var(--ctc-espresso);
	border-color: var(--ctc-cream);
}

/* ===========================================================================
 * Process 1-2-3
 * ======================================================================== */
.ctc-process__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1.5rem, 3vw, 3rem);
	counter-reset: ctc-step;
}

.ctc-process__step {
	border-top: var(--ctc-border-width) solid var(--ctc-hairline);
	padding-top: var(--ctc-space-5);
}

.ctc-process__num {
	display: block;
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: clamp(2.5rem, 1.5rem + 3vw, 4rem);
	line-height: 1;
	color: var(--ctc-bronze);
	margin-bottom: var(--ctc-space-4);
}

.ctc-process__title {
	font-family: var(--ctc-font-body);
	font-size: 1.125rem;
	font-weight: var(--ctc-weight-ui);
	letter-spacing: 0.02em;
	margin: 0 0 var(--ctc-space-2);
	color: var(--ctc-text);
}

.ctc-process__text {
	color: var(--ctc-text-muted);
	margin: 0;
}

.ctc-process__cta {
	margin-top: clamp(2rem, 4vw, 3rem);
}

/* ===========================================================================
 * Value props (3 columns)
 * ======================================================================== */
.ctc-props__intro {
	margin-top: var(--ctc-space-3);
	color: var(--ctc-text-muted);
	max-width: 60ch;
}

.ctc-props__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1.5rem, 3vw, 3rem);
}

.ctc-props__item {
	border-top: var(--ctc-border-width) solid var(--ctc-hairline);
	padding-top: var(--ctc-space-5);
}

.ctc-props__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: clamp(1.375rem, 1.1rem + 1vw, 1.75rem);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin: 0 0 var(--ctc-space-3);
	color: var(--ctc-text);
}

.ctc-props__text {
	color: var(--ctc-text-muted);
	margin: 0;
}

.ctc-props__cta {
	margin-top: clamp(2rem, 4vw, 3rem);
}

/* ===========================================================================
 * Two info cards
 * ======================================================================== */
.ctc-info__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(1.25rem, 2.5vw, 2rem);
}

.ctc-info__card {
	background: var(--ctc-sand);
	border-radius: var(--ctc-img-radius);
	padding: clamp(1.75rem, 1rem + 3vw, 3rem);
}

.ctc-info__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: clamp(1.5rem, 1.2rem + 1.2vw, 2rem);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin: 0 0 var(--ctc-space-3);
}

.ctc-info__text {
	color: var(--ctc-text-muted);
	margin: 0 0 var(--ctc-space-5);
	max-width: 44ch;
}

/* ===========================================================================
 * Category tile (.ctc-tile) — homepage §8 + store landing
 * ======================================================================== */
.ctc-tile {
	display: flex;
	flex-direction: column;
	gap: var(--ctc-space-3);
	text-decoration: none;
	color: var(--ctc-espresso);
}

.ctc-tile__media {
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1 / 1;
	border-radius: var(--ctc-img-radius);
	background: var(--ctc-sand);
	overflow: hidden;
}

.ctc-tile__img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 14%;
	mix-blend-mode: multiply;
	transition: transform var(--ctc-transition-slow);
}

.ctc-tile:hover .ctc-tile__img {
	transform: scale(1.05);
}

.ctc-tile__label {
	font-family: var(--ctc-font-body);
	font-size: 1rem;
	font-weight: var(--ctc-weight-ui);
	letter-spacing: 0.02em;
}

.ctc-tile__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	font-size: 0.6875rem;
	font-weight: var(--ctc-weight-ui);
	letter-spacing: var(--ctc-track-button);
	text-transform: uppercase;
	color: var(--ctc-text-faint);
}

.ctc-tile:hover .ctc-tile__cta {
	color: var(--ctc-walnut);
}

/* ===========================================================================
 * FAQ accordion (native <details>)
 * ======================================================================== */
.ctc-faq {
	border-top: var(--ctc-border-width) solid var(--ctc-hairline);
	max-width: 880px;
}

.ctc-faq__item {
	border-bottom: var(--ctc-border-width) solid var(--ctc-hairline);
}

.ctc-faq__q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ctc-space-4);
	padding: var(--ctc-space-5) 0;
	cursor: pointer;
	list-style: none;
	font-family: var(--ctc-font-body);
	font-size: 1.0625rem;
	font-weight: var(--ctc-weight-ui);
	color: var(--ctc-text);
}

.ctc-faq__q::-webkit-details-marker {
	display: none;
}

.ctc-faq__icon {
	position: relative;
	flex: none;
	width: 14px;
	height: 14px;
}

.ctc-faq__icon::before,
.ctc-faq__icon::after {
	content: "";
	position: absolute;
	background: var(--ctc-espresso);
	transition: transform var(--ctc-transition), opacity var(--ctc-transition);
}

.ctc-faq__icon::before {
	top: 6px;
	left: 0;
	width: 14px;
	height: 2px;
}

.ctc-faq__icon::after {
	top: 0;
	left: 6px;
	width: 2px;
	height: 14px;
}

.ctc-faq__item[open] .ctc-faq__icon::after {
	transform: rotate(90deg);
	opacity: 0;
}

.ctc-faq__a {
	padding: 0 0 var(--ctc-space-5);
	color: var(--ctc-text-muted);
	line-height: var(--ctc-leading-body);
	max-width: 70ch;
}

.ctc-faq__a p {
	margin: 0 0 var(--ctc-space-3);
}

/* ===========================================================================
 * Page hero (image + H1 + sub + advisory CTA)
 * ======================================================================== */
.ctc-page-hero {
	position: relative;
	padding-block: clamp(3rem, 2rem + 5vw, 6rem);
	background: var(--ctc-sand);
	overflow: hidden;
}

.ctc-page-hero--media {
	color: var(--ctc-cream);
}

.ctc-page-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	z-index: 0;
}

.ctc-page-hero--media .ctc-page-hero__bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(39, 23, 14, 0.35) 0%, rgba(39, 23, 14, 0.7) 100%);
}

.ctc-page-hero__inner {
	position: relative;
	z-index: 1;
}

.ctc-page-hero__overline {
	display: block;
	margin-bottom: var(--ctc-space-3);
}

.ctc-page-hero--media .ctc-page-hero__overline {
	color: var(--ctc-bronze);
}

.ctc-page-hero__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: var(--ctc-text-display);
	letter-spacing: var(--ctc-track-display);
	text-transform: uppercase;
	line-height: 1.05;
	margin: 0;
	max-width: 22ch;
	text-wrap: balance;
}

.ctc-page-hero__sub {
	margin: var(--ctc-space-5) 0 0;
	max-width: 56ch;
	font-size: 1.125rem;
	line-height: var(--ctc-leading-body);
}

.ctc-page-hero--media .ctc-page-hero__sub {
	color: rgba(246, 246, 245, 0.9);
}

.ctc-page-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ctc-space-3);
	margin-top: clamp(1.75rem, 3vw, 2.5rem);
}

.ctc-page-hero--media .ctc-btn--ghost {
	color: var(--ctc-cream);
	border-color: rgba(246, 246, 245, 0.6);
}

.ctc-page-hero--media .ctc-btn--ghost:hover,
.ctc-page-hero--media .ctc-btn--ghost:focus {
	background: var(--ctc-cream);
	color: var(--ctc-espresso);
	border-color: var(--ctc-cream);
}

/* ===========================================================================
 * Machine archive landing bits (handoff §7.2)
 * ======================================================================== */
.ctc-archive-cta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--ctc-space-3) var(--ctc-space-5);
	margin-top: var(--ctc-space-5);
}

.ctc-archive-cta__phone {
	color: var(--ctc-text-muted);
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	text-decoration: underline;
	text-underline-offset: 0.25em;
	text-decoration-thickness: 1px;
}

.ctc-archive-cta__phone:hover {
	color: var(--ctc-espresso);
}

.ctc-archive-faq {
	margin-top: var(--ctc-space-9);
}

.ctc-archive-faq__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: var(--ctc-text-title);
	letter-spacing: var(--ctc-track-display);
	text-transform: uppercase;
	margin: 0 0 var(--ctc-space-5);
}

/* ===========================================================================
 * Static pages — generic scaffolding (.ctc-page)
 * ======================================================================== */
.ctc-page {
	background: var(--ctc-bg);
}

.ctc-page .ctc-prose {
	max-width: 70ch;
	color: var(--ctc-text);
	line-height: var(--ctc-leading-body);
}

.ctc-page .ctc-prose h2 {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: var(--ctc-text-title);
	letter-spacing: var(--ctc-track-display);
	text-transform: uppercase;
	margin: clamp(2rem, 4vw, 3rem) 0 var(--ctc-space-4);
}

.ctc-page .ctc-prose h3 {
	font-size: 1.125rem;
	font-weight: var(--ctc-weight-ui);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin: var(--ctc-space-6) 0 var(--ctc-space-3);
}

.ctc-page .ctc-prose p,
.ctc-page .ctc-prose ul,
.ctc-page .ctc-prose ol {
	margin: 0 0 var(--ctc-space-4);
}

/* Two-column "content + aside" layout for service/leasing etc. */
.ctc-cols {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}

/* Comparison rows (Hvorfor leasing?). */
.ctc-compare {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: var(--ctc-border-width) solid var(--ctc-hairline);
}

.ctc-compare__row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--ctc-space-5);
	padding: var(--ctc-space-5) 0;
	border-bottom: var(--ctc-border-width) solid var(--ctc-hairline);
}

.ctc-compare__row h3 {
	font-size: var(--ctc-text-overline);
	letter-spacing: var(--ctc-track-overline);
	text-transform: uppercase;
	color: var(--ctc-text-faint);
	margin: 0 0 var(--ctc-space-2);
}

/* ===========================================================================
 * Erhvervsløsninger hub — segment cards (handoff §7.5)
 * ======================================================================== */
.ctc-segments__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1.25rem, 2.5vw, 2rem);
}

.ctc-segment-card {
	display: flex;
	flex-direction: column;
	gap: var(--ctc-space-3);
	padding: clamp(1.5rem, 1rem + 2vw, 2.25rem);
	background: var(--ctc-sand);
	border-radius: var(--ctc-img-radius);
	text-decoration: none;
	color: var(--ctc-espresso);
	transition: transform var(--ctc-transition), box-shadow var(--ctc-transition);
}

.ctc-segment-card:hover,
.ctc-segment-card:focus-visible {
	transform: translateY(-4px);
	box-shadow: var(--ctc-shadow-soft);
}

.ctc-segment-card__title {
	font-family: var(--ctc-font-heading);
	font-weight: var(--ctc-weight-display);
	font-size: 1.5rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin: 0;
}

.ctc-segment-card__text {
	color: var(--ctc-text-muted);
	font-size: 0.9375rem;
	margin: 0;
}

/* ===========================================================================
 * Store landing (handoff §7.4)
 * ======================================================================== */
.ctc-store__tiles {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(1rem, 2.5vw, 2rem);
}

.ctc-store__all {
	margin-top: clamp(2rem, 4vw, 3rem);
	text-align: center;
}

/* ===========================================================================
 * Kontakt page
 * ======================================================================== */
.ctc-contact__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}

.ctc-contact__block {
	display: grid;
	gap: var(--ctc-space-4);
}

.ctc-contact__item .ctc-overline {
	display: block;
	margin-bottom: var(--ctc-space-1);
	color: var(--ctc-text-faint);
}

.ctc-contact__item a {
	color: var(--ctc-espresso);
	text-decoration: none;
}

.ctc-contact__item a:hover {
	color: var(--ctc-walnut);
}

/* ===========================================================================
 * Blog / post cards (Viden page + homepage §14 teaser)
 * ======================================================================== */
.ctc-blog__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(1.25rem, 2.5vw, 2rem);
}

.ctc-postcard {
	display: flex;
}

.ctc-postcard__link {
	display: flex;
	flex-direction: column;
	gap: var(--ctc-space-3);
	text-decoration: none;
	color: var(--ctc-espresso);
}

.ctc-postcard__media {
	display: block;
	aspect-ratio: 3 / 2;
	border-radius: var(--ctc-img-radius);
	overflow: hidden;
	background: var(--ctc-sand);
}

.ctc-postcard__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--ctc-transition-slow);
}

.ctc-postcard__link:hover .ctc-postcard__img {
	transform: scale(1.04);
}

.ctc-postcard__title {
	font-family: var(--ctc-font-body);
	font-size: 1.0625rem;
	font-weight: var(--ctc-weight-ui);
	line-height: 1.35;
	margin: 0;
}

.ctc-postcard__excerpt {
	color: var(--ctc-text-muted);
	font-size: 0.9375rem;
	margin: 0;
}

.ctc-postcard__link:hover .ctc-postcard__cta .ctc-text-link__arrow {
	transform: translateX(4px);
}

.ctc-blog__pagination {
	margin-top: clamp(2.5rem, 4vw, 4rem);
	display: flex;
	flex-wrap: wrap;
	gap: var(--ctc-space-2);
	justify-content: center;
}

.ctc-blog__pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	padding: 0.5rem 0.75rem;
	color: var(--ctc-text-muted);
	font-size: 0.875rem;
	letter-spacing: 0.04em;
	text-decoration: none;
	transition: color var(--ctc-transition);
}

.ctc-blog__pagination .page-numbers.current,
.ctc-blog__pagination .page-numbers:hover {
	color: var(--ctc-espresso);
	box-shadow: inset 0 -1px 0 0 currentColor;
}

/* ===========================================================================
 * Responsive
 * ======================================================================== */
@media (max-width: 920px) {
	.ctc-process__list,
	.ctc-props__grid,
	.ctc-segments__grid {
		grid-template-columns: minmax(0, 1fr);
	}

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

	.ctc-info__grid,
	.ctc-cols,
	.ctc-contact__grid {
		grid-template-columns: minmax(0, 1fr);
	}

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

@media (max-width: 540px) {
	.ctc-store__tiles {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.ctc-blog__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.ctc-compare__row {
		grid-template-columns: minmax(0, 1fr);
		gap: var(--ctc-space-2);
	}
}

/* ===========================================================================
 * Reduced motion
 * ======================================================================== */
@media (prefers-reduced-motion: reduce) {
	.ctc-tile__img,
	.ctc-segment-card,
	.ctc-faq__icon::before,
	.ctc-faq__icon::after {
		transition: none;
	}

	.ctc-tile:hover .ctc-tile__img,
	.ctc-segment-card:hover {
		transform: none;
	}
}
