/* ==========================================================================
   iCAN Theme — Main Stylesheet
   Built for the International Center for Adolescents in Need
   ========================================================================== */

/* ---------- Brand tokens ---------- */
:root {
	--ican-navy:        #2E2E8C;
	--ican-navy-dark:   #1F1F66;
	--ican-purple:      #4B1F8F;
	--ican-purple-light:#7B4FBF;
	--ican-purple-bg:   #F4F0FA;
	--ican-teal:        #2DB8A8;
	--ican-teal-dark:   #1F8A7E;
	--ican-lime:        #B8D147;
	--ican-lime-dark:   #94AB37;
	--ican-cream:       #FBF9F5;
	--ican-ink:         #1A1A2E;
	--ican-ink-soft:    #4A4A5E;
	--ican-border:      #E8E4F0;
	--ican-white:       #FFFFFF;

	--font-display: "Playfair Display", Georgia, serif;
	--font-body:    "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

	--shadow-sm: 0 4px 16px rgba(75,31,143,0.06);
	--shadow-md: 0 10px 40px rgba(75,31,143,0.08);
	--shadow-lg: 0 20px 60px rgba(75,31,143,0.12);

	--radius-sm: 8px;
	--radius-md: 16px;
	--radius-lg: 24px;
	--radius-pill: 999px;

	--max-width: 1200px;
	--header-height: 88px;
}

/* ---------- Reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }

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

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: 17px;
	line-height: 1.65;
	color: var(--ican-ink);
	background: var(--ican-cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5, h6,
.site-content h1, .site-content h2, .site-content h3 {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--ican-navy);
	line-height: 1.2;
	margin: 0 0 0.6em;
	letter-spacing: -0.01em;
}
h1 { font-size: clamp(2rem, 4vw, 3.25rem); }
h2 { font-size: clamp(1.625rem, 3vw, 2.5rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.625rem); }

p { margin: 0 0 1.2em; }

a {
	color: var(--ican-purple);
	text-decoration: none;
	transition: color 180ms ease;
}
a:hover, a:focus { color: var(--ican-teal-dark); }

/* Focus rings — accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 3px solid var(--ican-lime);
	outline-offset: 2px;
	border-radius: 4px;
}

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

/* ---------- Accessibility ---------- */
.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 !important;
	width: 1px;
	word-wrap: normal !important;
}
.skip-link:focus {
	background: var(--ican-navy);
	color: var(--ican-white);
	display: block;
	font-size: 14px;
	font-weight: 600;
	padding: 14px 22px;
	position: fixed;
	top: 8px;
	left: 8px;
	clip: auto !important;
	clip-path: none;
	height: auto;
	width: auto;
	z-index: 99999;
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-md);
}

/* ---------- Crisis bar ---------- */
.crisis-bar {
	background: var(--ican-navy);
	color: var(--ican-white);
	font-size: 14px;
	font-weight: 500;
}
.crisis-bar__inner {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 10px 24px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
}
.crisis-bar__dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--ican-lime);
	box-shadow: 0 0 0 0 rgba(184,209,71,0.7);
	animation: ican-pulse 2s infinite;
}
@keyframes ican-pulse {
	0%   { box-shadow: 0 0 0 0 rgba(184,209,71,0.6); }
	70%  { box-shadow: 0 0 0 8px rgba(184,209,71,0); }
	100% { box-shadow: 0 0 0 0 rgba(184,209,71,0); }
}
.crisis-bar__label { font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; font-size: 12px; }
.crisis-bar__link { color: var(--ican-white); text-decoration: underline; text-underline-offset: 3px; }
.crisis-bar__link:hover { color: var(--ican-lime); }
.crisis-bar__sep { opacity: 0.4; }

/* ---------- Site header ---------- */
.site-header {
	background: var(--ican-white);
	border-bottom: 1px solid var(--ican-border);
	position: sticky;
	top: 0;
	z-index: 100;
	backdrop-filter: saturate(180%) blur(8px);
}
.site-header__inner {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 18px 24px;
	display: flex;
	align-items: center;
	gap: 32px;
}
.site-branding { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.custom-logo, .footer-logo { max-height: 56px; width: auto; }
.site-title {
	margin: 0;
	font-family: var(--font-display);
	font-size: 26px;
	font-weight: 700;
}
.site-title a { color: var(--ican-navy); }
.site-description {
	margin: 0;
	font-size: 12px;
	color: var(--ican-ink-soft);
	letter-spacing: 0.5px;
}

/* Primary nav */
.main-navigation { flex: 1; }
.primary-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 28px;
	justify-content: center;
	flex-wrap: wrap;
}
.primary-menu > li > a {
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 15px;
	color: var(--ican-ink);
	padding: 8px 2px;
	position: relative;
	letter-spacing: 0.2px;
}
.primary-menu > li > a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -4px;
	height: 2px;
	background: var(--ican-purple);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 240ms ease;
}
.primary-menu > li > a:hover { color: var(--ican-purple); }
.primary-menu > li > a:hover::after,
.primary-menu > li.current-menu-item > a::after { transform: scaleX(1); }

/* CTA button (used in header & inline) */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0.3px;
	padding: 12px 24px;
	border-radius: var(--radius-pill);
	border: 2px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: all 200ms ease;
	white-space: nowrap;
}
.btn--lime   { background: var(--ican-lime); color: var(--ican-navy); }
.btn--lime:hover { background: var(--ican-navy); color: var(--ican-white); }
.btn--navy   { background: var(--ican-navy); color: var(--ican-white); }
.btn--navy:hover { background: var(--ican-purple); color: var(--ican-white); }
.btn--outline {
	background: transparent;
	color: var(--ican-navy);
	border-color: var(--ican-navy);
}
.btn--outline:hover { background: var(--ican-navy); color: var(--ican-white); }

/* Mobile menu toggle */
.menu-toggle {
	display: none;
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 8px;
	position: relative;
	width: 40px;
	height: 40px;
}
.menu-toggle__bar {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--ican-navy);
	margin: 5px auto;
	transition: transform 200ms ease, opacity 200ms ease;
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- Content / blog ---------- */
.site-content { min-height: 40vh; }
.entry-default {
	max-width: 760px;
	margin: 0 auto;
	padding: 80px 24px;
}
.entry-default .entry-title {
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: 0.4em;
}
.entry-meta {
	font-family: var(--font-body);
	color: var(--ican-ink-soft);
	font-size: 14px;
	margin-bottom: 2.5em;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}
.entry-content > * + * { margin-top: 1.2em; }
.entry-content blockquote {
	border-left: 4px solid var(--ican-purple);
	margin: 2em 0;
	padding: 0.4em 0 0.4em 1.6em;
	font-family: var(--font-display);
	font-size: 1.4em;
	color: var(--ican-navy);
	font-style: italic;
}
.entry-content code, .entry-content pre {
	background: var(--ican-purple-bg);
	border-radius: var(--radius-sm);
	font-family: "SF Mono", Monaco, monospace;
	font-size: 0.9em;
	padding: 0.2em 0.4em;
}
.entry-content pre { padding: 1.2em; overflow-x: auto; }

/* Archive grid */
.archive-header {
	background: linear-gradient(135deg, var(--ican-navy) 0%, var(--ican-purple) 100%);
	color: var(--ican-white);
	padding: 80px 24px 64px;
	text-align: center;
}
.archive-header h1 { color: var(--ican-white); }
.archive-grid {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 64px 24px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 28px;
}
.archive-card {
	background: var(--ican-white);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform 260ms ease, box-shadow 260ms ease;
}
.archive-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}
.archive-card__thumb img { width: 100%; height: 220px; object-fit: cover; }
.archive-card__body { padding: 28px; }
.archive-card__title {
	font-family: var(--font-display);
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 12px;
}
.archive-card__title a { color: var(--ican-navy); }
.archive-card__excerpt { color: var(--ican-ink-soft); font-size: 15px; margin-bottom: 16px; }
.archive-card__meta {
	font-size: 12px;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--ican-teal-dark);
	font-weight: 600;
}

/* Pagination */
.pagination, .nav-links {
	max-width: var(--max-width);
	margin: 0 auto 80px;
	padding: 0 24px;
	display: flex;
	justify-content: center;
	gap: 8px;
}
.pagination .page-numbers,
.nav-links .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border-radius: var(--radius-sm);
	background: var(--ican-white);
	border: 1px solid var(--ican-border);
	color: var(--ican-navy);
	font-weight: 500;
	font-size: 14px;
}
.pagination .page-numbers.current,
.nav-links .page-numbers.current {
	background: var(--ican-purple);
	color: var(--ican-white);
	border-color: var(--ican-purple);
}

/* ---------- 404 page ---------- */
.error-404 {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 80px 24px;
	background: linear-gradient(135deg, var(--ican-navy) 0%, var(--ican-purple) 100%);
	color: var(--ican-white);
}
.error-404 h1 { color: var(--ican-white); font-size: 6rem; margin-bottom: 0.2em; }
.error-404 p { font-size: 1.25rem; opacity: 0.9; }
.error-404 .btn { margin-top: 24px; }

/* ---------- Footer ---------- */
.site-footer {
	background: var(--ican-ink);
	color: rgba(255,255,255,0.85);
	margin-top: 0;
}
.site-footer__top {
	padding: 80px 24px 60px;
}
.site-footer__grid {
	max-width: var(--max-width);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: 48px;
}
.site-footer__brand .footer-logo { max-height: 64px; margin-bottom: 16px; filter: brightness(0) invert(1); }
.footer-brand-title {
	color: var(--ican-white);
	font-size: 28px;
	margin: 0 0 16px;
}
.footer-tagline {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 18px;
	color: rgba(255,255,255,0.7);
	margin: 0 0 20px;
	line-height: 1.4;
}
.footer-address {
	font-style: normal;
	font-size: 14px;
	line-height: 1.8;
	color: rgba(255,255,255,0.7);
}
.footer-address a { color: var(--ican-lime); font-weight: 600; }
.footer-widget-title {
	font-family: var(--font-body);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--ican-lime);
	margin: 0 0 18px;
}
.footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
}
.footer-links li {
	font-size: 14px;
	padding: 6px 0;
	color: rgba(255,255,255,0.75);
}
.footer-links a { color: rgba(255,255,255,0.85); }
.footer-links a:hover { color: var(--ican-lime); }
.footer-links--crisis li strong { color: var(--ican-lime); font-weight: 700; margin-right: 4px; }

/* Partners row */
.site-footer__partners {
	border-top: 1px solid rgba(255,255,255,0.08);
	border-bottom: 1px solid rgba(255,255,255,0.08);
	padding: 24px 24px;
}
.partners-inner {
	max-width: var(--max-width);
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 32px;
	flex-wrap: wrap;
	justify-content: center;
}
.partners-label {
	font-size: 11px;
	letter-spacing: 2px;
	color: rgba(255,255,255,0.5);
	font-weight: 700;
}
.partners-list {
	display: flex;
	gap: 32px;
	flex-wrap: wrap;
	justify-content: center;
}
.partners-list span {
	font-family: var(--font-display);
	font-size: 15px;
	color: rgba(255,255,255,0.75);
	font-weight: 600;
}

/* Footer bottom */
.site-footer__bottom { padding: 24px; background: rgba(0,0,0,0.25); }
.footer-bottom-inner {
	max-width: var(--max-width);
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
}
.footer-copy { font-size: 13px; color: rgba(255,255,255,0.5); }
.footer-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 24px; }
.footer-menu a { font-size: 13px; color: rgba(255,255,255,0.7); }
.footer-menu a:hover { color: var(--ican-lime); }

/* ---------- Comments ---------- */
.comments-area { max-width: 760px; margin: 0 auto; padding: 0 24px 80px; }
.comments-title { font-size: 1.5rem; margin-bottom: 1em; }
.comment-list { list-style: none; padding: 0; }
.comment-body {
	background: var(--ican-white);
	border-radius: var(--radius-md);
	padding: 24px;
	margin-bottom: 20px;
	box-shadow: var(--shadow-sm);
}

/* ---------- Forms ---------- */
input[type="text"], input[type="email"], input[type="url"],
input[type="tel"], input[type="number"], input[type="search"],
textarea, select {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid var(--ican-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: 15px;
	background: var(--ican-white);
	color: var(--ican-ink);
	transition: border-color 180ms ease, box-shadow 180ms ease;
}
input:focus, textarea:focus, select:focus {
	border-color: var(--ican-purple);
	box-shadow: 0 0 0 3px rgba(75,31,143,0.12);
	outline: 0;
}
button, input[type="submit"] {
	background: var(--ican-navy);
	color: var(--ican-white);
	border: 0;
	padding: 14px 28px;
	border-radius: var(--radius-pill);
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 14px;
	cursor: pointer;
	transition: background 180ms ease;
}
button:hover, input[type="submit"]:hover { background: var(--ican-purple); }

/* ---------- Sidebar widgets ---------- */
.widget {
	background: var(--ican-white);
	border-radius: var(--radius-md);
	padding: 28px;
	margin-bottom: 24px;
	box-shadow: var(--shadow-sm);
}
.widget-title {
	font-family: var(--font-display);
	font-size: 18px;
	font-weight: 700;
	color: var(--ican-navy);
	margin: 0 0 16px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--ican-lime);
}
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget ul li { padding: 8px 0; border-bottom: 1px solid var(--ican-border); }
.widget ul li:last-child { border-bottom: 0; }

/* ---------- Elementor canvas template body class ---------- */
.elementor-template-canvas .site-header,
.elementor-template-canvas .site-footer,
.elementor-template-canvas .crisis-bar { display: none; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 860px) {
	.site-header__inner {
		flex-wrap: wrap;
		gap: 12px;
	}
	.menu-toggle { display: block; margin-left: auto; }
	.site-header__cta { order: 3; margin-left: auto; }
	.main-navigation {
		order: 4;
		width: 100%;
		max-height: 0;
		overflow: hidden;
		transition: max-height 300ms ease;
	}
	.main-navigation.is-open { max-height: 600px; }
	.primary-menu {
		flex-direction: column;
		gap: 4px;
		padding: 16px 0;
		align-items: flex-start;
	}
	.primary-menu > li { width: 100%; }
	.primary-menu > li > a {
		display: block;
		padding: 12px 0;
		border-bottom: 1px solid var(--ican-border);
		width: 100%;
	}
	.crisis-bar__inner { font-size: 13px; }
}

@media (max-width: 640px) {
	.site-footer__grid { grid-template-columns: 1fr; gap: 36px; }
	.footer-bottom-inner { flex-direction: column; text-align: center; }
	.archive-grid { padding: 40px 24px; gap: 20px; }
	.btn { padding: 11px 20px; font-size: 13px; }
	.site-header__inner { padding: 14px 18px; }
}

/* ---------- WordPress core classes ---------- */
.alignleft  { float: left;  margin: 0.5em 1.5em 1em 0; }
.alignright { float: right; margin: 0.5em 0 1em 1.5em; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.alignwide { max-width: 1200px; margin-left: auto; margin-right: auto; }
.alignfull { width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: 100vw; }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 13px; color: var(--ican-ink-soft); font-style: italic; margin-top: 8px; }
.sticky { position: relative; }
.bypostauthor { display: block; }
.gallery-caption { display: block; }
