/* App-specific styles — additions beyond the design system */

/* ── Article bullets ── */
.article-bullets {
	list-style: none;
	padding: 0;
	margin-bottom: var(--s5);
}
.article-bullets li {
	font: 600 1.0625rem/1.5rem var(--sans);
	color: var(--kk-ink);
	padding: var(--s1) 0;
	padding-left: var(--s4);
	position: relative;
}
.article-bullets li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.6em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--kk-brand-red);
}

/* ── Breadcrumbs ── */
.breadcrumbs {
	font: 400 0.8125rem/1 var(--sans);
	color: var(--kk-ink-muted);
	padding: var(--s4) 0 var(--s2);
}
.breadcrumbs a { color: var(--kk-ink-subtle); }
.breadcrumbs a:hover { color: var(--kk-ink); }

/* ── Tag bar ── */
.tag-bar {
	background: var(--kk-canvas);
	border-bottom: 1px solid var(--kk-rule);
}
.tag-bar__inner {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s1) var(--s3);
	padding: var(--s2) 0;
}
.tag-bar__tag {
	font: 700 0.75rem/1 var(--sans);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--kk-ink-subtle);
	text-decoration: none;
	white-space: nowrap;
	padding: var(--s1) 0;
	border-bottom: 2px solid transparent;
	transition: color var(--fast) var(--ease), border-color var(--fast) var(--ease);
}
.tag-bar__tag:hover {
	color: var(--kk-ink);
	border-bottom-color: var(--kk-brand-red);
}

/* ── Article body links ── */
.article-body a {
	color: var(--kk-brand-blue);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}
.article-body a:hover { color: var(--kk-ink); }

/* ── Sources section ── */
.article-body .sources {
	font: 400 0.875rem/1.5 var(--sans);
	color: var(--kk-ink-subtle);
	border-top: 1px solid var(--kk-rule);
	padding-top: var(--s3);
	margin-top: var(--s5);
}
.article-body .sources a { font-weight: 500; }

/* ── Auth ── */
.auth-card {
	max-width: 28rem;
	margin: var(--s8) auto;
	padding: var(--s6);
	background: var(--kk-white);
	border: 1px solid var(--kk-rule);
	border-radius: 4px;
}
.auth-card h1 {
	font: 700 1.5rem/1.2 var(--serif);
	margin-bottom: var(--s2);
}
.auth-card p {
	font: 400 0.9375rem/1.5 var(--sans);
	color: var(--kk-ink-subtle);
	margin-bottom: var(--s5);
}
.auth-form__field {
	margin-bottom: var(--s4);
}
.auth-form__field label {
	display: block;
	font: 600 0.875rem/1 var(--sans);
	margin-bottom: var(--s2);
	color: var(--kk-ink);
}
.auth-form__field input[type="email"] {
	width: 100%;
	padding: var(--s2) var(--s3);
	font: 400 1rem/1.5 var(--sans);
	border: 1px solid var(--kk-rule);
	border-radius: 3px;
	background: var(--kk-bg);
}
.auth-form__field input[type="email"]:focus {
	outline: 2px solid var(--kk-brand-blue);
	outline-offset: 1px;
	border-color: var(--kk-brand-blue);
}
.auth-form input[type="submit"] {
	width: 100%;
	padding: var(--s3) var(--s4);
	font: 600 0.9375rem/1 var(--sans);
	color: var(--kk-white);
	background: var(--kk-brand-blue);
	border: none;
	border-radius: 3px;
	cursor: pointer;
	transition: background var(--fast) var(--ease);
}
.auth-form input[type="submit"]:hover {
	background: var(--kk-ink);
}

/* ── Info box ── */
.info-box {
	background: var(--kk-canvas);
	border: 1px solid var(--kk-rule);
	padding: var(--s4);
	margin-bottom: var(--s5);
}
.info-box__date {
	font: 400 0.9375rem/1.4 var(--sans);
	color: var(--kk-ink-subtle);
}
.info-box__day {
	font-weight: 700;
	color: var(--kk-ink);
	text-transform: capitalize;
}
/* ── Weather forecast ── */
.info-box__weather {
	display: flex;
	gap: var(--s1);
	margin-top: var(--s3);
	padding-top: var(--s3);
	border-top: 1px solid var(--kk-rule);
	overflow: hidden;
}
.weather-day {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	flex: 1;
	min-width: 0;
}
.weather-day__label {
	font: 600 0.6875rem/1 var(--sans);
	color: var(--kk-ink-subtle);
	text-transform: capitalize;
}
.weather-day__icon {
	width: 20px;
	height: 20px;
	color: var(--kk-ink-subtle);
}
.weather-day__icon svg {
	width: 100%;
	height: 100%;
}
.weather-day__temp {
	font: 600 0.75rem/1 var(--sans);
	color: var(--kk-ink);
}

/* ── Mobile header ── */
@media (max-width: 599px) {
	.site-header__inner { flex-direction: column; gap: var(--s3); align-items: flex-start; }
}
