/*
Theme Name: Northline Coffee
Theme URI: https://wordpress2.reondev.com
Description: Child theme for a custom coffee shop landing page.
Author: OpenAI Codex
Template: hello-elementor
Version: 1.1.0
Text Domain: northline-coffee
*/

:root {
	--northline-bg: #f7f6f2;
	--northline-surface: #ffffff;
	--northline-surface-muted: #efede7;
	--northline-ink: #131313;
	--northline-ink-soft: #5f5a53;
	--northline-ink-faint: #867f76;
	--northline-line: #d7d2ca;
	--northline-line-strong: #bdb6ad;
	--northline-accent: #5d4030;
	--northline-accent-strong: #211a16;
	--northline-shell: min(1120px, calc(100vw - 2.5rem));
	--northline-radius: 8px;
	--northline-radius-sm: 6px;
	--northline-section: clamp(4rem, 8vw, 7rem);
	--northline-font-heading: "Sora", "Helvetica Neue", Helvetica, Arial, sans-serif;
	--northline-font-body: "Public Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	color-scheme: light;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	overflow-x: hidden;
	background: linear-gradient(180deg, #faf9f6 0%, var(--northline-bg) 100%);
	color: var(--northline-ink);
	font-family: var(--northline-font-body);
	line-height: 1.65;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
	-webkit-tap-highlight-color: rgba(19, 19, 19, 0.12);
}

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

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

p {
	margin: 0 0 1rem;
}

ul,
dl {
	margin: 0;
	padding: 0;
}

button,
a,
input,
textarea,
select {
	touch-action: manipulation;
}

h1,
h2,
h3 {
	margin: 0;
	font-family: var(--northline-font-heading);
	font-weight: 600;
	line-height: 1.02;
	letter-spacing: -0.04em;
	text-wrap: balance;
}

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

.skip-link {
	position: absolute;
	left: -9999px;
	top: 1rem;
	z-index: 1000;
	padding: 0.75rem 1rem;
	border-radius: var(--northline-radius-sm);
	background: var(--northline-ink);
	color: #fff;
}

.skip-link:focus-visible {
	left: 1rem;
}

a:focus-visible,
button:focus-visible {
	outline: 2px solid var(--northline-ink);
	outline-offset: 3px;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 30;
	background: rgba(247, 246, 242, 0.92);
	backdrop-filter: blur(10px);
	border-bottom: 1px solid rgba(19, 19, 19, 0.08);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.25rem;
	padding: 1rem 0;
}

.brand {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	min-width: 0;
}

.brand__icon {
	width: 40px;
	height: 40px;
	flex: none;
}

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

.brand__name {
	font-family: var(--northline-font-heading);
	font-size: 1.1rem;
	font-weight: 600;
	letter-spacing: -0.03em;
}

.brand__tagline {
	color: var(--northline-ink-faint);
	font-size: 0.8rem;
	letter-spacing: 0.01em;
	white-space: nowrap;
}

.site-nav {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1.25rem;
	font-size: 0.92rem;
	font-weight: 600;
	color: var(--northline-ink-soft);
}

.site-nav a,
.site-footer__links a,
.detail-list a {
	transition:
		color 160ms ease,
		border-color 160ms ease,
		background-color 160ms ease;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.site-footer__links a:hover,
.site-footer__links a:focus-visible,
.detail-list a:hover,
.detail-list a:focus-visible {
	color: var(--northline-ink);
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3rem;
	padding: 0.85rem 1.15rem;
	border: 1px solid transparent;
	border-radius: var(--northline-radius);
	font-size: 0.92rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	transition:
		background-color 160ms ease,
		border-color 160ms ease,
		color 160ms ease,
		transform 160ms ease;
}

.button:hover,
.button:focus-visible {
	transform: translateY(-1px);
}

.button--primary {
	background: var(--northline-ink);
	color: #fff;
}

.button--primary:hover,
.button--primary:focus-visible {
	background: var(--northline-accent-strong);
}

.button--secondary {
	background: transparent;
	border-color: var(--northline-line-strong);
	color: var(--northline-ink);
}

.button--secondary:hover,
.button--secondary:focus-visible {
	background: var(--northline-surface);
	border-color: var(--northline-ink);
}

.button--small {
	min-height: 2.75rem;
	padding-inline: 1rem;
}

.site-main {
	position: relative;
}

.section {
	padding: var(--northline-section) 0;
}

.section--tight {
	padding-top: clamp(2.25rem, 5vw, 3.25rem);
}

.section--bordered {
	border-top: 1px solid rgba(19, 19, 19, 0.08);
}

.anchor-section {
	scroll-margin-top: 5.75rem;
}

.eyebrow,
.panel__eyebrow,
.menu-panel__label {
	display: inline-block;
	margin-bottom: 1rem;
	color: var(--northline-ink-faint);
	font-size: 0.74rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.hero {
	padding-top: clamp(3rem, 7vw, 5rem);
}

.hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
	gap: clamp(2rem, 4vw, 4rem);
	align-items: start;
}

.hero__content {
	max-width: 44rem;
}

.hero__title {
	font-size: clamp(3.4rem, 7.8vw, 6.2rem);
	margin-bottom: 1.4rem;
}

.hero__lede {
	max-width: 38rem;
	font-size: 1.08rem;
	color: var(--northline-ink-soft);
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	margin: 2rem 0 2.25rem;
}

.hero__meta,
.data-strip__grid {
	list-style: none;
}

.hero__meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.hero__meta li {
	min-width: 0;
	padding-top: 1rem;
	border-top: 1px solid var(--northline-line);
}

.hero__meta span,
.data-strip__grid span,
.section-copy,
.card p,
.panel p,
.menu-list span,
.visit-card p,
.hours-panel__note,
.site-footer__summary p,
.content-shell p,
.content-shell li,
.entry-card p,
.note p {
	color: var(--northline-ink-soft);
}

.hero__meta span {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.hero__meta strong,
.hours-list dd,
.data-strip__grid strong {
	display: block;
	font-variant-numeric: tabular-nums;
}

.hero__rail {
	display: grid;
	gap: 1rem;
}

.panel,
.card,
.menu-panel,
.visit-card,
.hours-panel,
.content-shell,
.entry-card,
.cta-banner {
	background: var(--northline-surface);
	border: 1px solid var(--northline-line);
	border-radius: var(--northline-radius);
}

.panel,
.card,
.menu-panel,
.visit-card,
.hours-panel,
.content-shell,
.entry-card {
	padding: 1.5rem;
}

.panel h2,
.section-head h2,
.visit-card h2,
.cta-banner h2,
.content-shell h1,
.entry-card h2 {
	margin-bottom: 0.9rem;
}

.panel h2 {
	font-size: clamp(1.8rem, 3vw, 2.35rem);
}

.panel--accent {
	background: var(--northline-accent-strong);
	border-color: var(--northline-accent-strong);
	color: #fff;
}

.panel--accent .panel__eyebrow,
.panel--accent span {
	color: rgba(255, 255, 255, 0.72);
}

.panel__schedule {
	display: grid;
	gap: 1rem;
}

.panel__schedule div + div {
	padding-top: 1rem;
	border-top: 1px solid rgba(255, 255, 255, 0.16);
}

.panel__schedule strong {
	display: block;
	margin-bottom: 0.25rem;
	font-size: 1rem;
	font-variant-numeric: tabular-nums;
}

.data-strip {
	border-top: 1px solid rgba(19, 19, 19, 0.08);
	border-bottom: 1px solid rgba(19, 19, 19, 0.08);
}

.data-strip__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.data-strip__grid li {
	min-width: 0;
	padding: 1.6rem 1.25rem 1.6rem 0;
}

.data-strip__grid li:not(:last-child) {
	border-right: 1px solid rgba(19, 19, 19, 0.08);
	padding-right: 1.25rem;
}

.data-strip__grid strong {
	margin-bottom: 0.4rem;
	font-size: 0.96rem;
}

.data-strip__grid span {
	display: block;
	font-size: 0.9rem;
}

.section-intro,
.atmosphere-grid,
.visit-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(300px, 0.95fr);
	gap: clamp(2rem, 4vw, 3.5rem);
	align-items: start;
}

.section-head {
	max-width: 46rem;
}

.section-head h2,
.visit-card h2,
.cta-banner h2,
.content-shell h1 {
	font-size: clamp(2.3rem, 5vw, 4.1rem);
}

.principles-grid,
.menu-columns {
	display: grid;
	gap: 1rem;
}

.principles-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 2rem;
}

.card h3,
.menu-panel h3,
.note h3 {
	margin-bottom: 0.6rem;
	font-size: 1.1rem;
}

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

.menu-list {
	display: grid;
	gap: 1rem;
	list-style: none;
}

.menu-list li {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 0.85rem;
	padding-top: 1rem;
	border-top: 1px solid var(--northline-line);
}

.menu-list li:first-child {
	padding-top: 0;
	border-top: 0;
}

.menu-list strong {
	display: block;
	margin-bottom: 0.22rem;
	font-size: 0.98rem;
}

.menu-list span {
	display: block;
	font-size: 0.9rem;
}

.menu-list em {
	font-style: normal;
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

.notes-list {
	display: grid;
	gap: 0;
	border-top: 1px solid var(--northline-line);
}

.note {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 1rem;
	padding: 1.35rem 0;
	border-bottom: 1px solid var(--northline-line);
}

.note__index {
	display: inline-block;
	min-width: 2rem;
	color: var(--northline-ink-faint);
	font-size: 0.85rem;
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

.detail-list,
.hours-list {
	display: grid;
	gap: 0.9rem;
}

.detail-list {
	margin: 1.8rem 0 2rem;
}

.detail-list div,
.hours-list div {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 1rem;
	padding-bottom: 0.9rem;
	border-bottom: 1px solid var(--northline-line);
}

.detail-list dt,
.hours-list dt {
	color: var(--northline-ink-faint);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.detail-list dd,
.hours-list dd {
	margin: 0;
	text-align: right;
}

.hours-panel__note {
	margin-top: 1.35rem;
	font-size: 0.95rem;
}

.cta-banner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 1.75rem 1.5rem;
	background: linear-gradient(180deg, #fbfaf8 0%, #f1eee8 100%);
}

.site-footer {
	padding: 2.5rem 0 2rem;
}

.site-footer__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 1.5rem;
	align-items: end;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(19, 19, 19, 0.08);
}

.site-footer__summary {
	max-width: 36rem;
}

.site-footer__links {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.8rem 1.2rem;
	font-size: 0.92rem;
	font-weight: 600;
}

.content-area {
	padding: 4rem 0 5rem;
}

.content-shell {
	max-width: 52rem;
}

.content-shell .eyebrow {
	margin-bottom: 0.75rem;
}

.prose > *:last-child {
	margin-bottom: 0;
}

.post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}

.entry-card {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.entry-card__meta {
	color: var(--northline-ink-faint);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.pagination {
	margin-top: 2rem;
}

@media (max-width: 1100px) {
	.hero__meta,
	.data-strip__grid,
	.principles-grid,
	.menu-columns,
	.section-intro,
	.atmosphere-grid,
	.visit-grid,
	.site-footer__inner {
		grid-template-columns: 1fr;
	}

	.data-strip__grid li {
		padding-right: 0;
	}

	.data-strip__grid li:not(:last-child) {
		border-right: 0;
		padding-right: 0;
	}

	.site-footer__links {
		justify-content: flex-start;
	}
}

@media (max-width: 800px) {
	.site-header__inner,
	.cta-banner {
		flex-direction: column;
		align-items: flex-start;
	}

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

@media (max-width: 640px) {
	.shell {
		width: min(100vw - 1.5rem, 1120px);
	}

	.hero__title {
		font-size: clamp(2.7rem, 14vw, 4.3rem);
	}

	.hero__actions {
		flex-direction: column;
	}

	.button,
	.button--small {
		width: 100%;
	}

	.brand__tagline {
		white-space: normal;
	}

	.site-nav {
		gap: 0.8rem 1rem;
	}

	.note,
	.detail-list div,
	.hours-list div {
		grid-template-columns: 1fr;
	}

	.detail-list dd,
	.hours-list dd {
		text-align: left;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
