/**
 * Additional styles for Gagana-Samoa theme
 * This file complements the main style.css
 */

/* Smooth transitions */
a,
button,
input,
textarea,
.site-header,
.main-navigation a,
.widget a {
	transition: all 0.3s ease;
}

/* Enhanced focus styles for accessibility */
a:focus,
button:focus,
input:focus,
textarea:focus,
select:focus {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

/* Sticky header styles */
.site-header.scrolled {
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
	background-color: rgba(255, 255, 255, 0.98);
}

/* Body loaded state */
body.loaded {
	opacity: 1;
}

body:not(.loaded) {
	opacity: 0;
}

/* Read more button styling */
.read-more {
	display: inline-block;
	margin-top: 1rem;
	padding: 0.5rem 1.5rem;
	background-color: var(--color-primary);
	color: white;
	text-decoration: none;
	border-radius: var(--border-radius);
	font-weight: 600;
}

.read-more:hover {
	background-color: var(--color-brown-dark);
	color: white;
}

/* Form enhancements */
.search-form.focused .search-field {
	border-color: var(--color-primary);
}

/* Footer menu inline display */
.footer-menu {
	display: inline;
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-menu li {
	display: inline;
	margin: 0 0.5rem;
}

.footer-menu a {
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
}

.footer-menu a:hover {
	color: white;
}

/* Post navigation styling */
.post-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 2rem;
}

.post-navigation .post-title {
	display: block;
	font-weight: 400;
	margin-top: 0.25rem;
}

.post-navigation .meta-nav {
	font-weight: 600;
}

/* Pagination improvements */
.page-numbers {
	display: inline-block;
	padding: 0.5rem 1rem;
	margin: 0 0.25rem;
	background-color: var(--color-bg-light);
	color: var(--color-text);
	text-decoration: none;
	border-radius: var(--border-radius);
	font-weight: 400;
}

.page-numbers:hover,
.page-numbers.current {
	background-color: var(--color-primary);
	color: white;
}

/* Comments styling */
.comment-list .children {
	margin-left: 2rem;
	margin-top: 1rem;
}

.comment-author .avatar {
	float: left;
	margin-right: 1rem;
	border-radius: 50%;
}

.comment-metadata {
	font-size: 0.875rem;
	color: var(--color-text-light);
	margin-bottom: 0.5rem;
}

.comment-metadata a {
	color: inherit;
	text-decoration: none;
}

.comment-reply-link:hover {
	color: var(--color-primary);
}

/* Accessibility improvements */
.screen-reader-text:focus {
	background-color: var(--color-bg-light);
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: var(--color-text);
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Tables */
table {
	width: 100%;
	margin-bottom: var(--spacing-unit);
	border-collapse: collapse;
}

th,
td {
	padding: 0.75rem;
	text-align: left;
	border-bottom: 1px solid var(--color-border);
}

th {
	background-color: var(--color-bg-light);
	font-weight: 600;
	color: var(--color-headline);
}

/* Preformatted text and code blocks */
pre {
	background-color: var(--color-bg-light);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	font-family: 'Courier New', Courier, monospace;
	line-height: 1.6;
	margin-bottom: var(--spacing-unit);
	max-width: 100%;
	overflow: auto;
	padding: 1rem;
	white-space: pre-wrap;
	word-wrap: break-word;
}

code {
	background-color: var(--color-bg-light);
	border-radius: 3px;
	font-family: 'Courier New', Courier, monospace;
	padding: 0.125rem 0.25rem;
}

pre code {
	background-color: transparent;
	padding: 0;
}

/* Definition lists */
dl {
	margin-bottom: var(--spacing-unit);
}

dt {
	font-weight: 600;
	margin-bottom: 0.25rem;
}

dd {
	margin-left: 2rem;
	margin-bottom: 1rem;
}

/* Horizontal rule */
hr {
	background-color: var(--color-border);
	border: 0;
	height: 1px;
	margin: calc(var(--spacing-unit) * 2) 0;
}

/* Archive and category pages */
.taxonomy-description {
	background-color: var(--color-bg-light);
	padding: var(--spacing-unit);
	border-radius: var(--border-radius);
	margin-bottom: calc(var(--spacing-unit) * 2);
}

/* Author bio */
.author-info {
	background-color: var(--color-bg-light);
	padding: calc(var(--spacing-unit) * 1.5);
	border-radius: var(--border-radius);
	margin: calc(var(--spacing-unit) * 2) 0;
}

.author-avatar {
	float: left;
	margin-right: var(--spacing-unit);
}

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

.author-description h2 {
	margin-top: 0;
	color: var(--color-headline);
	font-weight: 600;
}

/* Mobile menu enhancements */
@media (max-width: 767px) {
	.menu-item-has-children.toggled > .sub-menu {
		display: block !important;
	}
	
	.main-navigation .menu-item-has-children > a::after {
		content: ' ▼';
		font-size: 0.75rem;
		vertical-align: middle;
	}
	
	.main-navigation .menu-item-has-children.toggled > a::after {
		content: ' ▲';
	}
}

/* Print styles enhancement */
@media print {
	.entry-content a[href]::after {
		content: " (" attr(href) ")";
	}
	
	pre,
	blockquote {
		page-break-inside: avoid;
	}
	
	h1, h2, h3, h4, h5, h6 {
		page-break-after: avoid;
	}
}