/*
Theme Name:        Dental Arts of Boston
Theme URI:         https://bostoncosmeticdentistma.com/
Author:            Dental Arts of Boston
Author URI:        https://bostoncosmeticdentistma.com/
Description:       A lightweight WordPress Full Site Editing (FSE) block theme for Dental Arts of Boston. Edit every part of the site — header, footer, pages, and homepage — directly in the WordPress Block Editor. No page builders required. Optimised for local SEO, Core Web Vitals, and patient conversion.
Version:           2.0.0
Requires at least: 6.5
Tested up to:      6.7
Requires PHP:      8.1
License:           GNU General Public License v2 or later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       dental-arts
Tags:              full-site-editing, block-theme, wide-blocks, custom-colors, custom-fonts, dental, local-business
*/

/* =============================================================================
   DESIGN TOKENS
   Mirrors theme.json so CSS can reference these via var().
   ============================================================================= */
:root {
	--da-navy:        #1a3558;
	--da-navy-dark:   #0f2038;
	--da-gold:        #c8a870;
	--da-gold-light:  #e8d4a8;
	--da-white:       #ffffff;
	--da-off-white:   #f7f8fc;
	--da-text:        #1f2937;
	--da-muted:       #6b7280;
	--da-border:      #e5e7eb;
	--da-radius-sm:   6px;
	--da-radius-md:   12px;
	--da-radius-lg:   20px;
	--da-shadow-sm:   0 1px 3px rgba(0, 0, 0, 0.08);
	--da-shadow-md:   0 4px 16px rgba(26, 53, 88, 0.12);
	--da-shadow-lg:   0 12px 40px rgba(26, 53, 88, 0.20);
	--da-transition:  0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

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

html {
	scroll-behavior: smooth;
}

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

/* =============================================================================
   ACCESSIBILITY
   ============================================================================= */
:focus-visible {
	outline: 3px solid var(--da-gold);
	outline-offset: 3px;
	border-radius: 3px;
}

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

/* =============================================================================
   ANNOUNCEMENT BAR
   ============================================================================= */
.announcement-bar {
	background: var(--da-navy-dark);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	padding: 10px 24px !important;
}

.announcement-bar p {
	color: var(--da-gold-light);
	font-size: 0.82rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	margin: 0;
}

.announcement-bar a {
	color: var(--da-gold);
	font-weight: 700;
	text-decoration: none;
}

.announcement-bar a:hover {
	text-decoration: underline;
}

/* =============================================================================
   SITE HEADER
   ============================================================================= */
.site-header {
	background: var(--da-white);
	border-bottom: 1px solid var(--da-border);
	box-shadow: var(--da-shadow-sm);
	position: sticky;
	top: 0;
	z-index: 999;
}

.header-top-bar {
	background: var(--da-off-white);
	border-bottom: 1px solid var(--da-border);
	padding: 8px 24px !important;
}

.header-top-bar p {
	color: var(--da-muted);
	font-size: 0.80rem;
	margin: 0;
}

.header-top-bar a {
	color: var(--da-muted);
	text-decoration: none;
}

.header-top-bar a:hover {
	color: var(--da-navy);
}

.header-main-row {
	padding: 14px 24px !important;
	gap: 20px;
}

/* =============================================================================
   NAVIGATION
   ============================================================================= */
.wp-block-navigation .wp-block-navigation-item__content {
	color: var(--da-navy) !important;
	font-size: 0.93rem;
	font-weight: 600;
	padding: 8px 12px;
	border-radius: var(--da-radius-sm);
	transition: color var(--da-transition), background var(--da-transition);
}

.wp-block-navigation .wp-block-navigation-item:hover > .wp-block-navigation-item__content {
	color: var(--da-gold) !important;
	background: var(--da-off-white);
}

.wp-block-navigation .wp-block-navigation__submenu-container {
	background: var(--da-white);
	border: 1px solid var(--da-border);
	border-radius: var(--da-radius-md);
	box-shadow: var(--da-shadow-md);
	padding: 8px;
	min-width: 220px;
}

.wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	border-radius: var(--da-radius-sm);
	font-weight: 500;
}

/* Mobile nav hamburger */
.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close {
	color: var(--da-navy) !important;
}

/* =============================================================================
   BUTTONS
   ============================================================================= */

/* Primary — gold fill */
.wp-block-button.is-style-primary .wp-block-button__link,
.wp-element-button.is-style-primary {
	background-color: var(--da-gold) !important;
	color: var(--da-navy) !important;
	font-weight: 700 !important;
	border: none !important;
	border-radius: var(--da-radius-sm) !important;
	padding: 13px 26px !important;
	letter-spacing: 0.01em;
	transition: background var(--da-transition), transform var(--da-transition), box-shadow var(--da-transition);
	text-decoration: none !important;
}

.wp-block-button.is-style-primary .wp-block-button__link:hover {
	background-color: #b8943a !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(200, 168, 112, 0.45) !important;
}

/* Outline White — for dark backgrounds */
.wp-block-button.is-style-outline-white .wp-block-button__link {
	background-color: transparent !important;
	color: var(--da-white) !important;
	border: 2px solid rgba(255, 255, 255, 0.55) !important;
	border-radius: var(--da-radius-sm) !important;
	padding: 11px 24px !important;
	font-weight: 600 !important;
	transition: background var(--da-transition), border-color var(--da-transition);
	text-decoration: none !important;
}

.wp-block-button.is-style-outline-white .wp-block-button__link:hover {
	background-color: rgba(255, 255, 255, 0.12) !important;
	border-color: var(--da-white) !important;
}

/* Navy fill */
.wp-block-button.is-style-navy .wp-block-button__link {
	background-color: var(--da-navy) !important;
	color: var(--da-white) !important;
	font-weight: 700 !important;
	border: none !important;
	border-radius: var(--da-radius-sm) !important;
	padding: 13px 26px !important;
	transition: background var(--da-transition), transform var(--da-transition);
	text-decoration: none !important;
}

.wp-block-button.is-style-navy .wp-block-button__link:hover {
	background-color: var(--da-navy-dark) !important;
	transform: translateY(-2px);
}

/* =============================================================================
   HERO SECTION
   ============================================================================= */
.hero-section {
	background: linear-gradient(135deg, var(--da-navy-dark) 0%, var(--da-navy) 60%, #1e4976 100%);
	position: relative;
	overflow: hidden;
}

.hero-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 20% 80%, rgba(200, 168, 112, 0.08) 0%, transparent 50%),
	                  radial-gradient(circle at 80% 20%, rgba(200, 168, 112, 0.05) 0%, transparent 50%);
	pointer-events: none;
}

/* =============================================================================
   PAGE HERO BANNER (interior pages)
   ============================================================================= */
.page-hero {
	background: linear-gradient(135deg, var(--da-navy-dark) 0%, var(--da-navy) 100%);
}

.page-hero h1 {
	color: var(--da-white) !important;
}

/* =============================================================================
   STAT ITEMS
   ============================================================================= */
.stat-number {
	display: block;
	font-size: 2.4rem;
	font-weight: 800;
	line-height: 1.1;
}

.stat-label {
	display: block;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.07em;
	margin-top: 4px;
	text-transform: uppercase;
}

/* =============================================================================
   SERVICE CARDS
   ============================================================================= */
.service-card {
	background: var(--da-white);
	border: 1.5px solid var(--da-border);
	border-radius: var(--da-radius-md);
	padding: 28px 24px 24px !important;
	transition: transform var(--da-transition), box-shadow var(--da-transition), border-color var(--da-transition);
}

.service-card:hover {
	border-color: var(--da-gold);
	box-shadow: var(--da-shadow-lg);
	transform: translateY(-4px);
}

.service-icon {
	display: block;
	font-size: 2rem;
	line-height: 1;
	margin-bottom: 14px;
}

.service-card h3 {
	font-size: 1.05rem;
	margin-bottom: 10px;
}

.service-card a {
	border-bottom: 2px solid var(--da-gold);
	color: var(--da-navy);
	font-size: 0.85rem;
	font-weight: 600;
	padding-bottom: 1px;
	text-decoration: none;
	transition: color var(--da-transition);
}

.service-card a:hover {
	color: var(--da-gold);
}

/* =============================================================================
   DOCTOR CARDS
   ============================================================================= */
.doctor-card {
	background: var(--da-white);
	border-radius: var(--da-radius-lg);
	box-shadow: var(--da-shadow-md);
	overflow: hidden;
	text-align: center;
	transition: transform var(--da-transition), box-shadow var(--da-transition);
}

.doctor-card:hover {
	box-shadow: var(--da-shadow-lg);
	transform: translateY(-6px);
}

.doctor-card .wp-block-image img,
.doctor-photo img {
	aspect-ratio: 3 / 4;
	object-fit: cover;
	object-position: top center;
	width: 100%;
}

.doctor-card-body {
	padding: 20px 18px 24px !important;
}

.doctor-specialty {
	color: var(--da-gold);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

/* =============================================================================
   TESTIMONIAL CARDS
   ============================================================================= */
.testimonial-card {
	background: var(--da-white);
	border: 1.5px solid var(--da-border);
	border-radius: var(--da-radius-md);
	padding: 24px !important;
	transition: box-shadow var(--da-transition);
}

.testimonial-card:hover {
	box-shadow: var(--da-shadow-md);
}

.testimonial-stars {
	color: #f59e0b;
	display: block;
	font-size: 1.05rem;
	letter-spacing: 3px;
	margin-bottom: 12px;
}

.wp-block-quote.testimonial-quote {
	border: none;
	margin: 0;
	padding: 0;
}

.wp-block-quote.testimonial-quote p {
	font-size: 0.92rem;
	font-style: italic;
	line-height: 1.7;
}

.wp-block-quote.testimonial-quote cite {
	color: var(--da-muted);
	font-size: 0.82rem;
	font-style: normal;
	font-weight: 600;
}

/* =============================================================================
   TRUST / CHECKLIST LIST
   ============================================================================= */
.trust-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.trust-list li {
	border-bottom: 1px solid var(--da-border);
	color: var(--da-text);
	font-size: 0.95rem;
	line-height: 1.6;
	padding: 11px 0;
}

.trust-list li:last-child {
	border-bottom: none;
}

/* =============================================================================
   AREA TAGS
   ============================================================================= */
.area-tag {
	background: var(--da-white);
	border: 1.5px solid var(--da-border);
	border-radius: 999px;
	color: var(--da-navy);
	display: inline-block;
	font-size: 0.83rem;
	font-weight: 500;
	margin: 4px;
	padding: 6px 16px;
	transition: background var(--da-transition), border-color var(--da-transition), color var(--da-transition);
}

.area-tag:hover {
	background: var(--da-navy);
	border-color: var(--da-navy);
	color: var(--da-white);
}

/* =============================================================================
   CTA SECTION
   ============================================================================= */
.cta-section {
	background: linear-gradient(135deg, var(--da-navy) 0%, var(--da-navy-dark) 100%) !important;
}

/* =============================================================================
   SITE FOOTER
   ============================================================================= */
.site-footer {
	background: var(--da-navy-dark);
}

.site-footer,
.site-footer p,
.site-footer li {
	color: rgba(255, 255, 255, 0.65);
}

.site-footer h4 {
	color: var(--da-white);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 16px;
	text-transform: uppercase;
}

.site-footer a {
	color: rgba(255, 255, 255, 0.65);
	text-decoration: none;
	transition: color var(--da-transition);
}

.site-footer a:hover {
	color: var(--da-gold);
}

.site-footer .wp-block-list {
	list-style: none;
	padding: 0;
}

.site-footer .wp-block-list li {
	margin-bottom: 8px;
}

.footer-divider {
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
	background: transparent !important;
	margin: 0 !important;
}

/* =============================================================================
   BLOG / ARCHIVE
   ============================================================================= */
.post-card {
	background: var(--da-white);
	border: 1.5px solid var(--da-border);
	border-radius: var(--da-radius-md);
	overflow: hidden;
	transition: box-shadow var(--da-transition), transform var(--da-transition);
}

.post-card:hover {
	box-shadow: var(--da-shadow-md);
	transform: translateY(-3px);
}

/* =============================================================================
   SECTION LABELS
   ============================================================================= */
.section-label {
	color: var(--da-gold);
	display: inline-block;
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

/* =============================================================================
   RESPONSIVE
   ============================================================================= */
@media (max-width: 781px) {
	.header-main-row {
		flex-wrap: wrap;
		gap: 12px;
		padding: 12px 16px !important;
	}

	.hero-section {
		padding-top: 60px !important;
		padding-bottom: 60px !important;
	}
}

@media (max-width: 600px) {
	.header-top-bar {
		display: none;
	}

	.stat-number {
		font-size: 1.8rem;
	}
}
