/* ===========================================================
   Stewart Law — Components
   Reusable building blocks: buttons, cards, eyebrows, glass
   panels, dividers, the credibility band. Used by homepage and
   intended to be reused on Phase 2 interior pages.
   =========================================================== */

/* ---------- Eyebrow (small uppercase label) ---------- */
.sl-eyebrow {
	display: inline-block;
	font-family: var(--sl-font-sans);
	font-size: var(--sl-fs-eyebrow);
	font-weight: 500;
	color: var(--sl-color-ink-mute);
	letter-spacing: var(--sl-tracking-eyebrow);
	text-transform: uppercase;
	margin: 0 0 var(--sl-s-3);
}

/* ---------- Buttons ----------
   Specificity is bumped (a.sl-btn) and key colors use !important
   because Kadence's parent link-color rules and theme.json color
   resolution can otherwise win the cascade and render text the
   same color as the button background. */

a.sl-btn,
button.sl-btn,
.sl-btn {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--sl-font-sans);
	font-size: 1rem;
	font-weight: 500;
	line-height: 1;
	padding: 0.95rem 1.5rem;
	border-radius: var(--sl-r-pill);
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none !important;
	box-shadow: none;
	transition:
		background-color var(--sl-dur-1) var(--sl-ease),
		color            var(--sl-dur-1) var(--sl-ease),
		border-color     var(--sl-dur-1) var(--sl-ease),
		transform        var(--sl-dur-1) var(--sl-ease),
		box-shadow       var(--sl-dur-1) var(--sl-ease);
}

a.sl-btn:hover,
.sl-btn:hover { transform: translateY(-1px); }

a.sl-btn--primary,
.sl-btn--primary {
	background: var(--sl-color-accent) !important;
	color: #ffffff !important;
	border-color: var(--sl-color-accent) !important;
	box-shadow: var(--sl-shadow-sm);
}
a.sl-btn--primary:visited,
.sl-btn--primary:visited { color: #ffffff !important; }

a.sl-btn--primary:hover,
a.sl-btn--primary:focus-visible,
.sl-btn--primary:hover,
.sl-btn--primary:focus-visible {
	background: var(--sl-color-accent-hi) !important;
	color: #ffffff !important;
	border-color: var(--sl-color-accent-hi) !important;
	box-shadow: var(--sl-shadow-md);
}

a.sl-btn--ghost,
.sl-btn--ghost {
	background: transparent !important;
	color: var(--sl-color-ink) !important;
	border-color: var(--sl-color-line) !important;
}
a.sl-btn--ghost:hover,
a.sl-btn--ghost:focus-visible,
.sl-btn--ghost:hover,
.sl-btn--ghost:focus-visible {
	border-color: var(--sl-color-ink) !important;
	color: var(--sl-color-ink) !important;
}

a.sl-btn--quiet,
.sl-btn--quiet {
	background: transparent !important;
	color: var(--sl-color-ink-soft) !important;
	padding: 0.95rem 0.75rem;
	border-color: transparent !important;
}
a.sl-btn--quiet:hover,
a.sl-btn--quiet:focus-visible,
.sl-btn--quiet:hover,
.sl-btn--quiet:focus-visible {
	color: var(--sl-color-ink) !important;
}

/* ---------- Section ---------- */
.sl-section {
	padding-block: clamp(var(--sl-s-6), 8vw, var(--sl-s-8));
}
.sl-section--tight   { padding-block: clamp(var(--sl-s-5), 6vw, var(--sl-s-6)); }
.sl-section--paper-tint { background: var(--sl-color-paper-tint); }

.sl-container {
	width: 100%;
	max-width: var(--sl-wide-w);
	margin-inline: auto;
	padding-inline: clamp(var(--sl-s-3), 4vw, var(--sl-s-5));
}

.sl-container--narrow { max-width: var(--sl-content-w); }

/* ---------- Card (used for practice-area grid) ---------- */
.sl-card {
	display: flex;
	flex-direction: column;
	gap: var(--sl-s-2);
	padding: var(--sl-s-4);
	background: #fff;
	border: 1px solid var(--sl-color-line);
	border-radius: var(--sl-r-lg);
	color: var(--sl-color-ink);
	text-decoration: none;
	transition:
		transform     var(--sl-dur-2) var(--sl-ease),
		border-color  var(--sl-dur-2) var(--sl-ease),
		box-shadow    var(--sl-dur-2) var(--sl-ease),
		background    var(--sl-dur-2) var(--sl-ease);
}

.sl-card:hover,
.sl-card:focus-visible {
	transform: translateY(-2px);
	border-color: rgba(31, 58, 95, 0.20);
	background: var(--sl-glass-bg);
	-webkit-backdrop-filter: var(--sl-glass-blur);
	backdrop-filter: var(--sl-glass-blur);
	box-shadow: var(--sl-glass-shadow);
}

.sl-card__title {
	font-family: var(--sl-font-serif);
	font-size: var(--sl-fs-h3);
	font-weight: 500;
	margin: 0;
	color: var(--sl-color-ink);
}

.sl-card__desc {
	font-size: var(--sl-fs-small);
	color: var(--sl-color-ink-soft);
	margin: 0;
	line-height: 1.55;
}

.sl-card__more {
	margin-top: auto;
	font-size: var(--sl-fs-small);
	font-weight: 500;
	color: var(--sl-color-accent);
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}
.sl-card__more::after {
	content: "→";
	transition: transform var(--sl-dur-1) var(--sl-ease);
}
.sl-card:hover .sl-card__more::after { transform: translateX(3px); }

/* ---------- Glass panel (used by final CTA) ---------- */
.sl-glass {
	background: var(--sl-glass-bg);
	-webkit-backdrop-filter: var(--sl-glass-blur);
	backdrop-filter: var(--sl-glass-blur);
	border: var(--sl-glass-border);
	border-radius: var(--sl-r-lg);
	box-shadow: var(--sl-glass-shadow);
}

/* ---------- Divider ---------- */
.sl-divider {
	height: 1px;
	background: var(--sl-color-line);
	border: 0;
	margin-block: var(--sl-s-5);
}

/* ---------- Credibility band ---------- */
.sl-cred {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--sl-s-3);
	flex-wrap: wrap;
	text-align: center;
	font-family: var(--sl-font-serif);
	font-size: var(--sl-fs-large);
	font-weight: 400;
	color: var(--sl-color-ink);
	line-height: 1.5;
	margin: 0;
}

.sl-cred__line {
	max-width: 70ch;
}

.sl-cred__rule {
	display: inline-block;
	width: 28px;
	height: 1px;
	background: var(--sl-color-line);
	flex-shrink: 0;
}

.sl-cred strong {
	font-weight: 500;
	color: var(--sl-color-ink);
}

/* Asterisk treatment — the glyph is already raised in most
   fonts, so we neutralize the default sup behavior and let it
   sit inline. A subtle accent color ties the marker to the
   matching footnote indicator below. */
.sl-cred sup,
.sl-cred__footnote sup {
	vertical-align: baseline;
	position: static;
	font-size: 1em;
	line-height: inherit;
	color: var(--sl-color-accent);
	font-weight: 600;
	margin-inline: 0.05em;
}

.sl-cred__footnote {
	max-width: 720px;
	margin: var(--sl-s-3) auto 0;
	text-align: center;
	font-family: var(--sl-font-sans);
	font-size: var(--sl-fs-small);
	color: var(--sl-color-ink-mute);
	line-height: 1.55;
}

/* ---------- Site header ---------- */
.sl-site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: var(--sl-glass-bg);
	-webkit-backdrop-filter: var(--sl-glass-blur);
	backdrop-filter: var(--sl-glass-blur);
	border-bottom: 1px solid var(--sl-color-line-soft);
}

.sl-site-header__inner {
	max-width: var(--sl-wide-w);
	margin-inline: auto;
	padding: var(--sl-s-2) clamp(var(--sl-s-3), 4vw, var(--sl-s-5));
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sl-s-3);
}

a.sl-site-header__brand,
.sl-site-header__brand {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--sl-color-ink) !important;
	text-decoration: none !important;
	flex-shrink: 0;
	padding-block: 0.25rem;
}

.sl-site-header__logo {
	height: 56px;
	width: auto;
	display: block;
	flex-shrink: 0;
}

.sl-site-header__brand-tag {
	font-family: var(--sl-font-sans);
	font-size: 0.65rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--sl-color-ink-mute);
	font-weight: 500;
	border-left: 1px solid var(--sl-color-line);
	padding-left: 0.75rem;
	line-height: 1.2;
}

@media (max-width: 720px) {
	.sl-site-header__logo { height: 44px; }
	.sl-site-header__brand-tag { display: none; }
}

.sl-site-header__nav {
	display: flex;
	align-items: center;
	gap: var(--sl-s-3);
	margin-left: auto;
}

.sl-site-header__nav .sl-nav-menu {
	display: flex;
	flex-wrap: nowrap;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
	align-items: center;
}

.sl-site-header__nav .sl-nav-menu li {
	margin: 0;
	padding: 0;
	position: relative;
}

.sl-site-header__nav .sl-nav-menu a {
	font-family: var(--sl-font-sans);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--sl-color-ink) !important;
	text-decoration: none !important;
	padding: 0.6rem 0.85rem;
	display: inline-block;
	transition: color var(--sl-dur-1) var(--sl-ease);
	white-space: nowrap;
}

.sl-site-header__nav .sl-nav-menu a:hover,
.sl-site-header__nav .sl-nav-menu a:focus-visible,
.sl-site-header__nav .sl-nav-menu .current-menu-item > a,
.sl-site-header__nav .sl-nav-menu .current_page_item > a,
.sl-site-header__nav .sl-nav-menu .current-menu-ancestor > a {
	color: var(--sl-color-accent) !important;
}

/* Dropdown indicator (chevron) on parent items */
.sl-site-header__nav .sl-nav-menu .menu-item-has-children > a::after {
	content: "";
	display: inline-block;
	width: 0.5em;
	height: 0.5em;
	margin-left: 0.4em;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	opacity: 0.6;
	transition: transform var(--sl-dur-1) var(--sl-ease);
}

.sl-site-header__nav .sl-nav-menu .menu-item-has-children:hover > a::after,
.sl-site-header__nav .sl-nav-menu .menu-item-has-children:focus-within > a::after {
	transform: translateY(0) rotate(225deg);
	opacity: 1;
}

/* Submenu */
.sl-site-header__nav .sl-nav-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translate(-50%, 6px);
	min-width: 260px;
	background: #fff;
	border: 1px solid var(--sl-color-line);
	border-radius: var(--sl-r-md);
	box-shadow: var(--sl-shadow-lg);
	padding: 0.5rem 0;
	margin: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--sl-dur-1) var(--sl-ease), transform var(--sl-dur-1) var(--sl-ease);
	z-index: 60;
}

.sl-site-header__nav .sl-nav-menu .menu-item-has-children:hover > .sub-menu,
.sl-site-header__nav .sl-nav-menu .menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	pointer-events: auto;
	transform: translate(-50%, 0);
}

.sl-site-header__nav .sl-nav-menu .sub-menu li {
	width: 100%;
}

.sl-site-header__nav .sl-nav-menu .sub-menu a {
	display: block;
	padding: 0.6rem 1rem;
	font-size: 0.9rem;
	white-space: normal;
}

.sl-site-header__nav .sl-nav-menu .sub-menu a:hover,
.sl-site-header__nav .sl-nav-menu .sub-menu a:focus-visible {
	background: var(--sl-color-paper-tint);
}

a.sl-site-header__cta {
	padding: 0.55rem 1rem;
	font-size: 0.875rem;
	margin-left: 0.5rem;
}

.sl-site-header__toggle {
	display: none;
	background: none;
	border: 1px solid var(--sl-color-line);
	border-radius: var(--sl-r-sm);
	padding: 0.5rem 0.65rem;
	cursor: pointer;
}

.sl-site-header__toggle span {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--sl-color-ink);
	margin: 4px 0;
	border-radius: 2px;
}

@media (max-width: 900px) {
	.sl-site-header__toggle { display: inline-flex; flex-direction: column; }
	.sl-site-header__nav {
		display: none;
		flex-direction: column;
		align-items: stretch;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		padding: var(--sl-s-3);
		background: var(--sl-color-paper);
		border-bottom: 1px solid var(--sl-color-line);
		gap: var(--sl-s-2);
	}
	.sl-site-header__nav.is-open { display: flex; }
	.sl-site-header__nav .sl-nav-menu {
		flex-direction: column;
		gap: 0.25rem;
		width: 100%;
	}
	.sl-site-header__nav .sl-nav-menu a {
		padding: 0.6rem 0.5rem;
		display: block;
	}
	/* Mobile: dropdown becomes inline expanded list */
	.sl-site-header__nav .sl-nav-menu .sub-menu {
		position: static;
		opacity: 1;
		pointer-events: auto;
		transform: none;
		box-shadow: none;
		border: none;
		background: transparent;
		padding: 0 0 0.5rem 1rem;
		min-width: 0;
	}
	.sl-site-header__nav .sl-nav-menu .menu-item-has-children > a::after { display: none; }
	a.sl-site-header__cta {
		text-align: center;
		width: 100%;
	}
}

/* ---------- Site footer ---------- */
.sl-footer {
	background: var(--sl-color-ink);
	color: #ffffff;
	margin-top: var(--sl-s-6);
}

.sl-footer__inner {
	max-width: var(--sl-wide-w);
	margin-inline: auto;
	padding: clamp(var(--sl-s-5), 6vw, var(--sl-s-6)) clamp(var(--sl-s-3), 4vw, var(--sl-s-5));
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sl-s-4);
}

@media (min-width: 720px) {
	.sl-footer__inner {
		grid-template-columns: 1.4fr 1fr 1fr 1fr;
		gap: var(--sl-s-5);
	}
}

.sl-footer__col p {
	margin: 0;
	font-family: var(--sl-font-sans);
	line-height: 1.55;
}

.sl-footer__brand-name {
	font-family: var(--sl-font-serif) !important;
	font-size: 1.5rem;
	font-weight: 500;
	color: #fff;
	letter-spacing: -0.005em;
	margin: 0 0 0.25rem !important;
}

.sl-footer__brand-tag {
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.7);
	font-weight: 500;
}

.sl-footer__label {
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.85) !important;
	font-weight: 600;
	margin: 0 0 0.5rem !important;
}

.sl-footer__line {
	font-size: 1rem;
	font-weight: 500;
	color: #ffffff !important;
}

.sl-footer__line a,
a.sl-footer__line,
.sl-footer p,
.sl-footer p a {
	color: #ffffff !important;
	text-decoration: none !important;
	transition: color var(--sl-dur-1) var(--sl-ease);
	font-weight: 500;
}

.sl-footer__line a:hover,
.sl-footer__line a:focus-visible {
	color: #fff !important;
}

.sl-footer__social {
	display: flex;
	gap: 0.5rem;
}

.sl-footer__social-link {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 255, 255, 0.18);
	color: rgba(255, 255, 255, 0.85) !important;
	text-decoration: none !important;
	transition: background var(--sl-dur-1) var(--sl-ease), border-color var(--sl-dur-1) var(--sl-ease);
}

.sl-footer__social-link:hover,
.sl-footer__social-link:focus-visible {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.4);
}

.sl-footer__social-link svg {
	width: 18px;
	height: 18px;
}

.sl-footer__legal {
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	padding: var(--sl-s-3) clamp(var(--sl-s-3), 4vw, var(--sl-s-5));
}

.sl-footer__legal > p {
	max-width: var(--sl-wide-w);
	margin: 0 auto;
	padding: 0;
	font-family: var(--sl-font-sans);
	line-height: 1.55;
}

.sl-footer__copyright {
	font-size: 0.875rem;
	color: #ffffff;
	margin-bottom: 0.5rem !important;
}

.sl-footer__disclaimer {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.78);
	letter-spacing: 0.01em;
}

