/*
Theme Name: Halo Taiwan
Theme URI: https://halotaiwan.com
Author: Halo Taiwan
Author URI: https://halotaiwan.com
Description: Theme berita nasional untuk Halo Taiwan — portal berita berbahasa Indonesia seputar Taiwan. Ringan, cepat, mobile-first, dan siap untuk Google AdSense.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.6
Requires PHP: 7.1
License: GNU General Public License v2 or later
License URI: license.txt
Text Domain: halotaiwan
Tags: news, blog, one-column, two-columns, right-sidebar, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, block-styles, wide-blocks
*/

/* =========================================================
   1. RESET & BASE
   ========================================================= */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: 16px;
	line-height: 1.65;
	color: var(--ht-text);
	background-color: var(--ht-background);
	-webkit-font-smoothing: antialiased;
}

:root {
	--ht-primary: #C8102E;
	--ht-secondary: #FFFFFF;
	--ht-accent: #8B0000;
	--ht-background: #F8F8F8;
	--ht-text: #111111;
	--ht-border: #E5E5E5;
	--ht-link-hover: #A4001D;
	--ht-container: 1200px;
	--ht-radius: 4px;
	--ht-header-height: 64px;
}

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

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

a:hover,
a:focus {
	color: var(--ht-link-hover);
}

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

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 .5em;
	line-height: 1.3;
	font-weight: 700;
	color: var(--ht-text);
}

p {
	margin: 0 0 1.2em;
}

button {
	font-family: inherit;
	cursor: pointer;
}

input,
textarea,
select {
	font-family: inherit;
	font-size: 1rem;
}

/* Accessibility: skip link */
.skip-link {
	position: absolute;
	top: -100px;
	left: 0;
	background: var(--ht-primary);
	color: #fff;
	padding: 10px 18px;
	z-index: 100000;
	transition: top .2s ease;
}

.skip-link:focus {
	top: 0;
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	overflow: hidden;
	position: absolute !important;
	word-wrap: normal !important;
}

:focus-visible {
	outline: 2px solid var(--ht-primary);
	outline-offset: 2px;
}

.container {
	max-width: var(--ht-container);
	margin: 0 auto;
	padding: 0 20px;
}

/* =========================================================
   2. HEADER & STICKY NAVIGATION
   ========================================================= */
.site-header {
	position: sticky;
	top: 0;
	z-index: 900;
	background: var(--ht-secondary);
	border-bottom: 3px solid var(--ht-primary);
	box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--ht-header-height);
	gap: 20px;
}

.site-branding {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
}

.site-branding img.custom-logo {
	max-height: 40px;
	width: auto;
}

.site-branding__text {
	font-size: 1.5rem;
	font-weight: 800;
	letter-spacing: -.5px;
	color: var(--ht-primary);
}

.site-branding__text span {
	color: var(--ht-text);
}

.main-navigation {
	flex-grow: 1;
	display: flex;
	justify-content: center;
}

.main-navigation ul.menu {
	display: flex;
	align-items: center;
	gap: 4px;
}

.main-navigation .menu-item > a {
	display: inline-block;
	padding: 10px 16px;
	font-weight: 600;
	font-size: .95rem;
	border-radius: var(--ht-radius);
	transition: color .15s ease, background-color .15s ease;
}

.main-navigation .menu-item > a:hover,
.main-navigation .menu-item.current-menu-item > a {
	color: var(--ht-primary);
	background: rgba(200, 16, 46, .07);
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.header-actions button {
	background: none;
	border: none;
	padding: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	color: var(--ht-text);
	transition: background-color .15s ease;
}

.header-actions button:hover {
	background: var(--ht-background);
	color: var(--ht-primary);
}

.header-actions svg {
	width: 20px;
	height: 20px;
}

.menu-toggle {
	display: none;
}

/* Search overlay */
.search-overlay {
	position: fixed;
	inset: 0;
	background: rgba(17, 17, 17, .6);
	z-index: 1000;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: 12vh;
	opacity: 0;
	visibility: hidden;
	transition: opacity .2s ease;
}

.search-overlay.is-active {
	opacity: 1;
	visibility: visible;
}

.search-overlay__panel {
	background: var(--ht-secondary);
	width: 100%;
	max-width: 620px;
	margin: 0 20px;
	padding: 48px 24px 24px;
	border-radius: var(--ht-radius);
	position: relative;
}

.search-overlay .search-form {
	display: flex;
	gap: 8px;
}

.search-overlay__close {
	position: absolute;
	top: 12px;
	right: 12px;
	background: none;
	border: none;
	font-size: 1.4rem;
	line-height: 1;
	padding: 6px;
	color: var(--ht-text);
}

/* Search form */
.search-form {
	display: flex;
	width: 100%;
}

.search-form__input {
	flex-grow: 1;
	padding: 12px 14px;
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius) 0 0 var(--ht-radius);
	border-right: none;
}

.search-form__submit {
	background: var(--ht-primary);
	color: #fff;
	border: none;
	padding: 0 20px;
	border-radius: 0 var(--ht-radius) var(--ht-radius) 0;
	font-weight: 600;
}

.search-form__submit:hover {
	background: var(--ht-link-hover);
}

/* Mobile nav drawer */
@media (max-width: 900px) {
	.main-navigation {
		position: fixed;
		top: var(--ht-header-height);
		left: 0;
		right: 0;
		bottom: 0;
		background: var(--ht-secondary);
		transform: translateX(-100%);
		transition: transform .25s ease;
		overflow-y: auto;
		padding: 10px 0;
		z-index: 950;
		justify-content: flex-start;
	}

	.main-navigation.is-open {
		transform: translateX(0);
	}

	.main-navigation ul.menu {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.main-navigation .menu-item > a {
		display: block;
		padding: 16px 24px;
		border-bottom: 1px solid var(--ht-border);
		border-radius: 0;
	}

	.menu-toggle {
		display: flex;
	}
}

/* =========================================================
   3. BREAKING NEWS TICKER
   ========================================================= */
.breaking-news {
	background: var(--ht-primary);
	color: #fff;
	overflow: hidden;
}

.breaking-news__inner {
	display: flex;
	align-items: center;
	height: 42px;
}

.breaking-news__label {
	flex-shrink: 0;
	background: var(--ht-accent);
	font-weight: 700;
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .5px;
	padding: 0 16px;
	height: 100%;
	display: flex;
	align-items: center;
	gap: 6px;
}

.breaking-news__track-wrap {
	overflow: hidden;
	flex-grow: 1;
	height: 100%;
	position: relative;
}

.breaking-news__track {
	display: flex;
	align-items: center;
	position: absolute;
	white-space: nowrap;
	height: 100%;
	animation: ht-marquee 35s linear infinite;
	will-change: transform;
}

.breaking-news__track-wrap:hover .breaking-news__track {
	animation-play-state: paused;
}

.breaking-news__track a {
	padding: 0 40px 0 0;
	font-size: .9rem;
	font-weight: 500;
}

.breaking-news__track a:hover {
	text-decoration: underline;
	color: #fff;
}

@keyframes ht-marquee {
	from { transform: translateX(0); }
	to { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
	.breaking-news__track {
		animation: none;
		overflow-x: auto;
	}
}

/* =========================================================
   4. LAYOUT / SECTIONS
   ========================================================= */
.section {
	padding: 36px 0;
}

.section + .section {
	border-top: 1px solid var(--ht-border);
}

.section__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 20px;
	border-bottom: 3px solid var(--ht-primary);
	padding-bottom: 10px;
}

.section__title {
	font-size: 1.4rem;
	margin: 0;
	text-transform: uppercase;
	letter-spacing: .3px;
}

.section__more {
	font-size: .85rem;
	font-weight: 600;
	color: var(--ht-primary);
	white-space: nowrap;
}

.section__more:hover {
	color: var(--ht-link-hover);
}

.content-layout {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 40px;
	align-items: start;
}

@media (max-width: 900px) {
	.content-layout {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
   5. HERO SECTION
   ========================================================= */
.hero {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 24px;
	padding: 28px 0;
}

.hero__main {
	position: relative;
	border-radius: var(--ht-radius);
	overflow: hidden;
	background: #000;
}

.hero__main img {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	opacity: .92;
}

.hero__overlay {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 24px;
	background: linear-gradient(0deg, rgba(0, 0, 0, .85) 0%, rgba(0, 0, 0, 0) 100%);
}

.hero__overlay .category-badge {
	margin-bottom: 10px;
}

.hero__overlay h1,
.hero__overlay h2 {
	color: #fff;
	font-size: 1.75rem;
	margin: 0 0 8px;
}

.hero__overlay a {
	color: #fff;
}

.hero__meta {
	color: rgba(255, 255, 255, .8);
	font-size: .85rem;
}

.hero__side {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

@media (max-width: 900px) {
	.hero {
		grid-template-columns: 1fr;
	}
}

/* =========================================================
   6. CARDS / GRID
   ========================================================= */
.news-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}

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

.news-grid--2 {
	grid-template-columns: repeat(2, 1fr);
}

@media (max-width: 1024px) {
	.news-grid,
	.news-grid--3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.news-grid,
	.news-grid--3,
	.news-grid--2 {
		grid-template-columns: 1fr;
	}
}

.news-card {
	display: flex;
	flex-direction: column;
}

.news-card__thumb {
	position: relative;
	overflow: hidden;
	border-radius: var(--ht-radius);
	background: var(--ht-border);
	margin-bottom: 12px;
}

.news-card__thumb img {
	aspect-ratio: 16/10;
	object-fit: cover;
	width: 100%;
	transition: transform .35s ease;
}

.news-card:hover .news-card__thumb img {
	transform: scale(1.05);
}

.news-card__title {
	font-size: 1.05rem;
	margin: 0 0 8px;
}

.news-card__title a {
	transition: color .15s ease;
}

.news-card__excerpt {
	font-size: .9rem;
	color: #444;
	margin: 0 0 8px;
}

.news-card__meta {
	font-size: .78rem;
	color: #777;
	display: flex;
	gap: 10px;
	align-items: center;
	margin-top: auto;
}

/* Post list (archive/category/search results) */
.post-list {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.news-card--row {
	flex-direction: row;
	gap: 24px;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--ht-border);
}

.news-card--row .news-card__thumb {
	width: 280px;
	flex-shrink: 0;
	margin-bottom: 0;
}

.news-card--row .news-card__body {
	flex-grow: 1;
	min-width: 0;
}

@media (max-width: 600px) {
	.news-card--row {
		flex-direction: column;
	}

	.news-card--row .news-card__thumb {
		width: 100%;
	}
}

/* Horizontal list card (used in sidebar / trending / most popular) */
.news-list {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.news-list-item {
	display: flex;
	gap: 14px;
}

.news-list-item__rank {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--ht-border);
	line-height: 1;
	width: 28px;
	flex-shrink: 0;
}

.news-list-item__thumb {
	flex-shrink: 0;
	width: 90px;
	border-radius: var(--ht-radius);
	overflow: hidden;
}

.news-list-item__thumb img {
	aspect-ratio: 4/3;
	object-fit: cover;
}

.news-list-item__title {
	font-size: .95rem;
	margin: 0 0 6px;
	line-height: 1.35;
}

.news-list-item__meta {
	font-size: .75rem;
	color: #777;
}

.news-list--columns {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px 32px;
}

@media (max-width: 700px) {
	.news-list--columns {
		grid-template-columns: 1fr;
	}
}

/* Category badge */
.category-badge {
	display: inline-block;
	background: var(--ht-primary);
	color: #fff;
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .4px;
	padding: 4px 10px;
	border-radius: 3px;
}

.category-badge:hover {
	background: var(--ht-link-hover);
	color: #fff;
}

/* =========================================================
   7. SIDEBAR / WIDGETS
   ========================================================= */
.widget {
	margin-bottom: 32px;
	background: var(--ht-secondary);
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius);
	padding: 20px;
}

.widget-title {
	font-size: 1.1rem;
	text-transform: uppercase;
	border-bottom: 3px solid var(--ht-primary);
	padding-bottom: 10px;
	margin-bottom: 16px;
}

.widget ul li {
	padding: 8px 0;
	border-bottom: 1px solid var(--ht-border);
}

.widget ul li:last-child {
	border-bottom: none;
}

.widget select,
.widget input {
	width: 100%;
	padding: 10px;
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius);
}

/* =========================================================
   8b. NEWSLETTER (opt-in via Customizer)
   ========================================================= */
.newsletter {
	background: var(--ht-accent);
	color: #fff;
	border-radius: var(--ht-radius);
	padding: 40px;
	text-align: center;
}

.newsletter h2 {
	color: #fff;
	font-size: 1.5rem;
}

.newsletter p {
	color: rgba(255, 255, 255, .85);
	max-width: 560px;
	margin: 0 auto 20px;
}

.newsletter .widget {
	background: transparent;
	border: none;
	padding: 0;
	max-width: 480px;
	margin: 0 auto;
}

/* =========================================================
   8c. AD ZONES
   ========================================================= */
.ad-zone-wrap {
	display: flex;
	justify-content: center;
	margin: 20px 0;
}

.ad-zone-wrap .widget {
	background: transparent;
	border: none;
	padding: 0;
	margin: 0;
	max-width: 100%;
}

.ad-zone-wrap--header {
	margin: 0 0 0;
	padding: 12px 0;
	background: var(--ht-background);
	border-bottom: 1px solid var(--ht-border);
}

.ad-zone-wrap--footer {
	background: var(--ht-background);
	padding: 20px 0;
	margin: 0;
}

/* =========================================================
   9. BREADCRUMB
   ========================================================= */
.breadcrumb {
	font-size: .82rem;
	color: #666;
	padding: 14px 0;
}

.breadcrumb a:hover {
	text-decoration: underline;
}

.breadcrumb__sep {
	margin: 0 6px;
	color: #aaa;
}

/* =========================================================
   10. SINGLE ARTICLE
   ========================================================= */
.article-header {
	max-width: 820px;
	margin: 0 auto 24px;
}

.article-header .category-badge {
	margin-bottom: 14px;
}

.article-title {
	font-size: 2rem;
	line-height: 1.25;
}

.article-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px;
	font-size: .85rem;
	color: #666;
	border-top: 1px solid var(--ht-border);
	border-bottom: 1px solid var(--ht-border);
	padding: 14px 0;
	margin-top: 16px;
}

.article-meta__author {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	color: var(--ht-text);
}

.article-meta__author img {
	border-radius: 50%;
	width: 32px;
	height: 32px;
}

.article-featured-image {
	max-width: 900px;
	margin: 0 auto 30px;
	border-radius: var(--ht-radius);
	overflow: hidden;
}

.article-featured-image img {
	width: 100%;
}

.article-layout {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	gap: 40px;
	max-width: 1040px;
	margin: 0 auto;
	align-items: start;
}

@media (max-width: 900px) {
	.article-layout {
		grid-template-columns: 1fr;
	}
}

.article-aside {
	position: sticky;
	top: calc(var(--ht-header-height) + 20px);
	display: flex;
	flex-direction: column;
	gap: 20px;
}

@media (max-width: 900px) {
	.article-aside {
		position: static;
		flex-direction: row;
		flex-wrap: wrap;
	}
}

.share-buttons {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

@media (max-width: 900px) {
	.share-buttons {
		flex-direction: row;
	}
}

.share-buttons__label {
	font-size: .78rem;
	text-transform: uppercase;
	font-weight: 700;
	color: #777;
	margin-bottom: 4px;
}

.share-button {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 9px 14px;
	border-radius: var(--ht-radius);
	border: 1px solid var(--ht-border);
	font-size: .85rem;
	font-weight: 600;
}

.share-button:hover {
	border-color: var(--ht-primary);
	color: var(--ht-primary);
}

.share-button svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.toc {
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius);
	padding: 16px;
}

.toc__title {
	font-size: .82rem;
	text-transform: uppercase;
	font-weight: 700;
	margin-bottom: 10px;
}

.toc ol {
	counter-reset: toc-counter;
}

.toc li {
	counter-increment: toc-counter;
	margin-bottom: 8px;
	font-size: .85rem;
}

.toc li.toc__item--sub {
	margin-left: 16px;
}

.toc a {
	color: #444;
}

.toc a:hover,
.toc a.is-active {
	color: var(--ht-primary);
	font-weight: 600;
}

.reading-progress {
	position: fixed;
	top: 0;
	left: 0;
	height: 3px;
	width: 0%;
	background: var(--ht-primary);
	z-index: 1200;
	transition: width .1s linear;
}

.article-content {
	max-width: 100%;
	font-size: 1.05rem;
}

.article-content h2 {
	font-size: 1.5rem;
	margin-top: 1.6em;
	scroll-margin-top: calc(var(--ht-header-height) + 16px);
}

.article-content h3 {
	font-size: 1.2rem;
	margin-top: 1.4em;
	scroll-margin-top: calc(var(--ht-header-height) + 16px);
}

.article-content img {
	border-radius: var(--ht-radius);
	margin: 1.2em 0;
}

.article-content a {
	color: var(--ht-primary);
	text-decoration: underline;
}

.article-content blockquote {
	border-left: 4px solid var(--ht-primary);
	padding: 4px 20px;
	margin: 1.5em 0;
	font-style: italic;
	color: #444;
}

.article-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 30px 0;
}

.article-tags a {
	border: 1px solid var(--ht-border);
	border-radius: 20px;
	padding: 6px 14px;
	font-size: .8rem;
}

.article-tags a:hover {
	border-color: var(--ht-primary);
	color: var(--ht-primary);
}

.author-box {
	display: flex;
	gap: 16px;
	background: var(--ht-background);
	border-radius: var(--ht-radius);
	padding: 20px;
	margin: 30px 0;
}

.author-box img {
	border-radius: 50%;
	width: 56px;
	height: 56px;
	flex-shrink: 0;
}

.author-box__name {
	font-weight: 700;
	margin-bottom: 4px;
}

.author-box__bio {
	font-size: .88rem;
	color: #555;
}

/* Prev / Next navigation */
.post-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin: 40px 0;
}

@media (max-width: 600px) {
	.post-nav {
		grid-template-columns: 1fr;
	}
}

.post-nav__item {
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius);
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.post-nav__item:hover {
	border-color: var(--ht-primary);
}

.post-nav__direction {
	font-size: .72rem;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--ht-primary);
}

.post-nav__next {
	text-align: right;
	align-items: flex-end;
}

/* Related articles */
.related-articles {
	margin: 50px 0;
}

/* =========================================================
   11. PAGINATION
   ========================================================= */
.pagination {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin: 36px 0;
	flex-wrap: wrap;
}

.pagination a,
.pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius);
	font-size: .9rem;
}

.pagination a:hover {
	border-color: var(--ht-primary);
	color: var(--ht-primary);
}

.pagination .current {
	background: var(--ht-primary);
	border-color: var(--ht-primary);
	color: #fff;
	font-weight: 700;
}

/* =========================================================
   12. COMMENTS
   ========================================================= */
.comments-area {
	max-width: 820px;
	margin: 40px auto 0;
}

.comments-title {
	font-size: 1.3rem;
	border-bottom: 3px solid var(--ht-primary);
	padding-bottom: 10px;
}

.comment-list {
	margin-top: 20px;
}

.comment-list .children {
	margin-left: 40px;
}

@media (max-width: 600px) {
	.comment-list .children {
		margin-left: 16px;
	}
}

.comment-body {
	border-bottom: 1px solid var(--ht-border);
	padding: 18px 0;
}

.comment-author {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	margin-bottom: 6px;
}

.comment-author img {
	border-radius: 50%;
}

.comment-metadata {
	font-size: .78rem;
	color: #888;
	font-weight: 400;
}

.comment-reply-link {
	font-size: .8rem;
	font-weight: 600;
	color: var(--ht-primary);
}

.comment-respond {
	margin-top: 30px;
	background: var(--ht-background);
	padding: 24px;
	border-radius: var(--ht-radius);
}

.comment-form p {
	margin-bottom: 14px;
}

.comment-form label {
	display: block;
	font-size: .85rem;
	font-weight: 600;
	margin-bottom: 6px;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--ht-border);
	border-radius: var(--ht-radius);
}

.comment-form-submit input {
	background: var(--ht-primary);
	color: #fff;
	border: none;
	padding: 12px 26px;
	border-radius: var(--ht-radius);
	font-weight: 700;
}

.comment-form-submit input:hover {
	background: var(--ht-link-hover);
}

/* =========================================================
   13. FOOTER
   ========================================================= */
.site-footer {
	background: var(--ht-text);
	color: rgba(255, 255, 255, .75);
	margin-top: 40px;
	padding: 40px 0 20px;
}

.site-footer__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
	text-align: center;
}

.site-footer .site-branding__text {
	color: #fff;
}

.site-footer .site-branding__text span {
	color: var(--ht-primary);
}

.footer-nav ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px 24px;
}

.footer-nav a:hover {
	color: #fff;
}

.site-footer__copyright {
	font-size: .82rem;
	border-top: 1px solid rgba(255, 255, 255, .15);
	padding-top: 20px;
	width: 100%;
	text-align: center;
}

/* =========================================================
   14. COOKIE CONSENT
   ========================================================= */
.cookie-consent {
	position: fixed;
	left: 20px;
	right: 20px;
	bottom: 20px;
	max-width: 480px;
	background: var(--ht-text);
	color: #fff;
	padding: 18px 20px;
	border-radius: var(--ht-radius);
	z-index: 1300;
	display: flex;
	flex-direction: column;
	gap: 12px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, .25);
	transform: translateY(150%);
	transition: transform .3s ease;
}

.cookie-consent.is-visible {
	transform: translateY(0);
}

.cookie-consent p {
	margin: 0;
	font-size: .85rem;
	color: rgba(255, 255, 255, .85);
}

.cookie-consent__actions {
	display: flex;
	gap: 10px;
}

.cookie-consent__accept {
	background: var(--ht-primary);
	color: #fff;
	border: none;
	padding: 10px 18px;
	border-radius: var(--ht-radius);
	font-weight: 700;
	font-size: .85rem;
}

.cookie-consent__decline {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, .3);
	color: #fff;
	padding: 10px 18px;
	border-radius: var(--ht-radius);
	font-size: .85rem;
}

/* =========================================================
   15. GENERIC PAGE / ARCHIVE HEADER
   ========================================================= */
.page-header {
	padding: 24px 0;
	border-bottom: 3px solid var(--ht-primary);
	margin-bottom: 30px;
}

.page-title {
	font-size: 1.8rem;
	text-transform: uppercase;
}

.page-description {
	color: #666;
	margin-top: 8px;
}

.page-content-single {
	max-width: 820px;
	margin: 0 auto;
}

/* No results */
.no-results {
	text-align: center;
	padding: 60px 20px;
}

.no-results__search {
	max-width: 480px;
	margin: 20px auto 0;
}

/* Widget: search form inside sidebar */
.widget .search-form {
	flex-direction: column;
	gap: 8px;
}

.widget .search-form__input {
	border-radius: var(--ht-radius);
	border-right: 1px solid var(--ht-border);
}

.widget .search-form__submit {
	border-radius: var(--ht-radius);
	padding: 10px;
}

/* Alignment helpers (block editor) */
.alignwide {
	max-width: 1100px;
}

.alignfull {
	max-width: 100%;
}

/* Print */
@media print {
	.site-header,
	.breaking-news,
	.article-aside,
	.site-footer,
	.cookie-consent,
	.related-articles,
	.post-nav,
	.comments-area {
		display: none !important;
	}
}
