
/*
Theme Name: Morris & Dewett Legal
Theme URI: https://morrisdewett.com
Description: Custom theme for Morris & Dewett service pages with automated content deployment
Version: 1.0.0
Author: Morris & Dewett
Author URI: https://morrisdewett.com
License: Proprietary
Text Domain: morris-dewett-legal
*/

/* Typography - Import Google Fonts */
@import url("https://cdn-dekmpl.nitrocdn.com/QSxHQCkwkFNEByddOHGYxYbAjuXYOvVN/assets/static/source/rev-c1e510e/fonts.googleapis.com/60b5696660b000fc7c84edf7d2ef369a.css2");

/* Proxima Nova alternatives for web-safe fallback */

/* If you have Proxima Nova licensed, add it via @font-face here */

/* CSS Variables - Morris & Dewett Brand Colors */
:root {
	--color-primary: #c1aa85;
	/* Gold accent */
	--color-secondary: #000;
	/* Black */
	--color-accent: #191919;
	/* Dark gray-black */
	--color-text: #fff;
	/* White text */
	--color-text-light: #f5f5f5;
	/* Off-white */
	--color-link: #c1aa85;
	/* Gold links */
	--color-background: #0d0d0d;
	/* Near-black background */
	--font-heading: "Oswald", sans-serif;
	--font-body: "Proxima Nova", Arial, sans-serif;
	--spacing-base: 25px;
	--spacing-large: 50px;
	--content-max-width: 1200px;
}

/* Reset and Base Styles */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: var(--font-body);
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-text);
	background: var(--color-background);
	font-weight: 400;
}

/* Container */
.site-container {
	max-width: var(--content-max-width);
	margin: 0 auto;
	padding: 0 var(--spacing-base);
}

/* Header */
.site-header {
	background: var(--color-secondary);
	color: var(--color-text);
	padding: 20px 0;
	border-bottom: 2px solid var(--color-primary);
}

.site-title {
	font-family: var(--font-heading);
	font-size: 32px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin: 0;
}

.site-title a {
	color: var(--color-text);
	text-decoration: none;
}

.site-title a:hover {
	color: var(--color-primary);
}

/* Main Content */
.site-main {
	padding: var(--spacing-large) 0;
	background: var(--color-background);
}

/* Service Page Content Area */
.service-content {
	max-width: var(--content-max-width);
	margin: 0 auto;
}

/* Headings - Morris & Dewett Style */
.service-content h1 {
	font-family: var(--font-heading);
	font-size: 50px;
	font-weight: 900;
	line-height: 1.15em;
	margin-bottom: var(--spacing-base);
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 1px;
}

.service-content h2 {
	font-family: var(--font-heading);
	font-size: 40px;
	font-weight: 900;
	line-height: 1.15em;
	margin: var(--spacing-large) 0 var(--spacing-base);
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 1px;
}

.service-content h3 {
	font-family: var(--font-heading);
	font-size: 28px;
	font-weight: 700;
	line-height: 1.15em;
	margin: var(--spacing-base) 0 15px;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 1px;
}

.service-content h4 {
	font-family: var(--font-heading);
	font-size: 24px;
	font-weight: 500;
	line-height: 1.15em;
	margin: var(--spacing-base) 0 15px;
	color: var(--color-text-light);
	text-transform: uppercase;
}

/* Paragraphs and Body Text */
.service-content p {
	margin-bottom: var(--spacing-base);
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-text);
}

/* Links - Gold Accent */
.service-content a {
	color: var(--color-link);
	font-weight: 700;
	text-decoration: underline;
	transition: opacity .3s ease;
}

.service-content a:hover {
	opacity: .8;
}

/* Lists */
.service-content ul, .service-content ol {
	margin: var(--spacing-base) 0;
	padding-left: 40px;
	color: var(--color-text);
}

.service-content li {
	margin-bottom: 10px;
	line-height: 1.6;
}

/* Table of Contents */
.toc {
	background: var(--color-accent);
	border: 2px solid var(--color-primary);
	padding: var(--spacing-base);
	margin: var(--spacing-base) 0;
}

.toc h3 {
	margin-top: 0;
	color: var(--color-primary);
}

.toc ul {
	list-style: none;
	padding-left: 0;
}

.toc li {
	margin-bottom: 10px;
}

.toc a {
	color: var(--color-text);
	font-weight: 400;
}

.toc a:hover {
	color: var(--color-primary);
}

/* Blockquotes and Citations */
.service-content blockquote {
	border-left: 4px solid var(--color-primary);
	padding-left: 20px;
	margin: var(--spacing-base) 0;
	font-style: italic;
	color: var(--color-text-light);
}

.service-content cite {
	color: var(--color-primary);
	font-style: normal;
	font-weight: 700;
}

/* FAQ/Definition Lists */
.service-content dl {
	margin: var(--spacing-large) 0;
}

.service-content dt {
	font-family: var(--font-heading);
	font-size: 24px;
	font-weight: 900;
	color: var(--color-primary);
	margin: 40px 0 15px 0;
	text-transform: none;
	line-height: 1.3;
	letter-spacing: .5px;
}

/* First question shouldn't have top margin */
.service-content dt:first-of-type {
	margin-top: 0;
}

.service-content dd {
	margin: 0 0 0 0;
	padding: 20px 25px;
	background: #000;
	border: 2px solid #2a2a2a;
	border-left: 4px solid var(--color-primary);
	line-height: 1.8;
	font-size: 17px;
}

/* FAQ Question/Answer Pairing */
.service-content dt strong {
	font-family: var(--font-heading);
	font-size: 24px;
	font-weight: 900;
	color: var(--color-primary);
	display: block;
	letter-spacing: .5px;
}

/* Contact Section */
.service-content address {
	font-style: normal;
	background: var(--color-accent);
	padding: var(--spacing-base);
	margin: var(--spacing-base) 0;
	border-left: 4px solid var(--color-primary);
}

/* Footer */
.site-footer {
	background: var(--color-secondary);
	color: var(--color-text);
	padding: var(--spacing-large) 0;
	margin-top: var(--spacing-large);
	border-top: 2px solid var(--color-primary);
}

.footer-content {
	text-align: center;
}

.footer-content p {
	margin-bottom: 15px;
}

.footer-content a {
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 700;
}

.footer-content a:hover {
	text-decoration: underline;
}

/* Buttons and CTAs */
.btn {
	display: inline-block;
	padding: 15px 30px;
	background: var(--color-primary);
	color: var(--color-secondary);
	font-family: var(--font-heading);
	font-size: 18px;
	font-weight: 700;
	text-transform: uppercase;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: opacity .3s ease;
}

.btn:hover {
	opacity: .85;
}

.btn-secondary {
	background: var(--color-secondary);
	color: var(--color-primary);
	border: 2px solid var(--color-primary);
}

/* Utility Classes */
.text-gold {
	color: var(--color-primary);
}

.text-center {
	text-align: center;
}

.mt-large {
	margin-top: var(--spacing-large);
}

.mb-large {
	margin-bottom: var(--spacing-large);
}

.speakable {
	/* Styling for speakable content (voice assistants) */
	font-weight: 400;
}

/* Responsive - Mobile Optimizations */
@media (max-width: 768px) {
	:root {
		--spacing-base: 20px;
		--spacing-large: 25px;
	}
	
	body {
		font-size: 16px;
	}
	
	.site-container {
		padding: 0 15px;
	}
	
	.service-content h1 {
		font-size: 34px;
	}
	
	.service-content h2 {
		font-size: 30px;
	}
	
	.service-content h3 {
		font-size: 24px;
	}
	
	.service-content h4 {
		font-size: 20px;
	}
	
	.service-content p {
		font-size: 16px;
	}
}

@media (max-width: 540px) {
	.site-main {
		padding: 25px 0;
	}
	
	.service-content h1 {
		font-size: 28px;
	}
	
	.service-content h2 {
		font-size: 24px;
	}
	
	.toc {
		padding: 15px;
	}
	
	.btn {
		padding: 10px 20px;
		font-size: 16px;
	}
}

/* Archive Pages */
.archive-header, .category-header, .author-header, .search-header {
	margin-bottom: var(--spacing-large);
	border-bottom: 2px solid var(--color-primary);
	padding-bottom: var(--spacing-base);
}

.archive-description, .category-description, .author-bio {
	margin-top: 15px;
	color: var(--color-text-light);
	font-size: 16px;
}

.archive-post, .category-post, .author-post, .search-result {
	margin-bottom: var(--spacing-large);
	padding-bottom: var(--spacing-base);
	border-bottom: 1px solid var(--color-accent);
}

.archive-post h2, .category-post h2, .author-post h2, .search-result h2 {
	font-size: 32px;
	margin-bottom: 10px;
}

.archive-post h2 a, .category-post h2 a, .author-post h2 a, .search-result h2 a {
	color: var(--color-text-light);
	text-decoration: none;
}

.archive-post h2 a:hover, .category-post h2 a:hover, .author-post h2 a:hover, .search-result h2 a:hover {
	color: var(--color-primary);
}

.post-meta {
	color: var(--color-primary);
	font-size: 14px;
	font-family: var(--font-heading);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 15px;
}

.read-more {
	color: var(--color-primary);
	font-weight: 700;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 14px;
	letter-spacing: 1px;
}

.read-more:hover {
	text-decoration: underline;
}

/* Search Form */
.search-form {
	display: flex;
	gap: 10px;
	margin: var(--spacing-base) 0;
}

.search-field {
	flex: 1;
	padding: 12px 20px;
	background: var(--color-accent);
	border: 2px solid var(--color-primary);
	color: var(--color-text);
	font-size: 16px;
	font-family: var(--font-body);
}

.search-field:focus {
	outline: none;
	border-color: var(--color-text-light);
}

.search-submit {
	padding: 12px 30px;
	background: var(--color-primary);
	color: var(--color-secondary);
	border: none;
	font-family: var(--font-heading);
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	cursor: pointer;
	transition: opacity .3s ease;
}

.search-submit:hover {
	opacity: .85;
}

.search-count {
	color: var(--color-primary);
	font-size: 14px;
	margin-bottom: var(--spacing-base);
}

.no-results {
	text-align: center;
	padding: var(--spacing-large) 0;
}

.no-results h2 {
	color: var(--color-primary);
}

/* Pagination */
.pagination {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin: var(--spacing-large) 0;
}

.page-numbers {
	padding: 10px 15px;
	background: var(--color-accent);
	color: var(--color-text);
	text-decoration: none;
	border: 1px solid var(--color-primary);
	transition: all .3s ease;
}

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

/* Screen Reader Text */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

/* Print Styles */
@media print {
	body {
		background: #fff;
		color: #000;
	}
	
	.site-header, .site-footer, .toc {
		display: none;
	}
}
