/* =========================================================================
   Asendar — trauma-informed website design system
   Warm, low-arousal, nature-derived. No pure white, no pure black, no red.
   Sage (Intention) · Dusty blue (Insight) · Clay (Integration) on warm oat.
   Mirrors docs/design/asendar-palette.md. Light is the brand; dark supported.
   ========================================================================= */

:root {
	--asd-canvas: #f4f0e7;
	--asd-surface: #fcfaf4;
	--asd-surface-2: #efeadd;
	--asd-drawer: #ede7da;
	--asd-field: #f7f3ea;
	--asd-border: #e2dacb;
	--asd-border-strong: #d4cbb8;
	--asd-text: #322e27;
	--asd-text-2: #6e6757;
	--asd-text-muted: #968e7c;
	--asd-send: #5e7e63;
	--asd-active-bg: #e0e9dc;
	--asd-active-fg: #3e5a41;

	--asd-sage: #4f6b53;
	--asd-sage-deep: #3e5a41;
	--asd-sage-tile: #e2ebdd;
	--asd-blue: #566a88;
	--asd-blue-deep: #46546e;
	--asd-blue-tile: #e4e8f0;
	--asd-clay: #8a6a52;
	--asd-clay-deep: #6e513e;
	--asd-clay-tile: #efe2d5;

	--serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--radius: 14px;
	--radius-sm: 11px;
	--maxw: 1120px;
}

[data-theme="dark"] {
	--asd-canvas: #1c1a16;
	--asd-surface: #262320;
	--asd-surface-2: #2b2722;
	--asd-drawer: #232019;
	--asd-field: #2b2722;
	--asd-border: #3a352d;
	--asd-border-strong: #4a4438;
	--asd-text: #ece6da;
	--asd-text-2: #b7ae9b;
	--asd-text-muted: #8a8273;
	--asd-send: #6e8e73;
	--asd-active-bg: #2e3a2c;
	--asd-active-fg: #b6d2b6;

	--asd-sage: #9dbe9d;
	--asd-sage-deep: #b6d2b6;
	--asd-sage-tile: #2a3328;
	--asd-blue: #9db1ce;
	--asd-blue-deep: #b9c6dd;
	--asd-blue-tile: #272d38;
	--asd-clay: #c7a081;
	--asd-clay-deep: #d8b89c;
	--asd-clay-tile: #352b22;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }

body {
	font-family: var(--sans);
	background: var(--asd-canvas);
	color: var(--asd-text);
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 1.5rem; }

a { color: var(--asd-sage); text-decoration: none; transition: color 0.2s ease; }
a:hover { color: var(--asd-sage-deep); }

h1, h2, h3 { font-family: var(--serif); font-weight: 500; color: var(--asd-text); letter-spacing: 0.01em; line-height: 1.15; }

.eyebrow {
	font-family: var(--sans);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--asd-sage);
}

/* ---------- Navbar ---------- */
.navbar {
	position: sticky; top: 0; z-index: 100;
	background: color-mix(in srgb, var(--asd-canvas) 88%, transparent);
	backdrop-filter: saturate(120%) blur(10px);
	border-bottom: 0.5px solid var(--asd-border);
}
.nav-container {
	max-width: var(--maxw); margin: 0 auto; padding: 0 1.5rem;
	height: 66px; display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.logo {
	font-family: var(--serif); font-size: 1.5rem; font-weight: 600;
	letter-spacing: 0.04em; color: var(--asd-sage-deep);
}
.logo:hover { color: var(--asd-sage-deep); }
.nav-menu { display: flex; gap: 1.6rem; list-style: none; align-items: center; }
.nav-menu a {
	font-family: var(--sans); font-size: 0.9rem; font-weight: 500; color: var(--asd-text-2);
}
.nav-menu a:hover { color: var(--asd-sage-deep); }
.nav-actions { display: flex; align-items: center; gap: 0.75rem; }
.dark-mode-toggle {
	background: transparent; border: 0.5px solid var(--asd-border-strong);
	border-radius: 100px; width: 38px; height: 32px; cursor: pointer; font-size: 0.9rem; line-height: 1;
	color: var(--asd-text-2);
}
.dark-mode-toggle .light-icon { display: none; }
[data-theme="dark"] .dark-mode-toggle .light-icon { display: inline; }
[data-theme="dark"] .dark-mode-toggle .dark-icon { display: none; }
.btn-trial-nav {
	background: var(--asd-send); color: #fff; font-family: var(--sans);
	font-size: 0.85rem; font-weight: 600; padding: 0.5rem 1.1rem; border-radius: 100px;
}
.btn-trial-nav:hover { color: #fff; opacity: 0.92; }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px; }
.hamburger span { width: 22px; height: 2px; background: var(--asd-text); border-radius: 2px; transition: 0.25s; }
.hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.synergy-promo-banner { background: var(--asd-sage-tile); border-top: 0.5px solid var(--asd-border); }
.synergy-promo-banner__inner {
	max-width: var(--maxw); margin: 0 auto; padding: 0.55rem 1.5rem;
	text-align: center; font-size: 0.85rem; color: var(--asd-sage-deep);
}
.synergy-promo-banner__inner a { color: var(--asd-sage-deep); font-weight: 600; text-decoration: underline; }

/* ---------- Buttons ---------- */
.btn-primary, .btn-secondary {
	display: inline-flex; align-items: center; gap: 0.45rem; font-family: var(--sans);
	font-size: 0.95rem; font-weight: 600; padding: 0.8rem 1.6rem; border-radius: 100px;
	cursor: pointer; border: 0.5px solid transparent; transition: 0.2s; position: relative; overflow: hidden;
}
.btn-primary { background: var(--asd-send); color: #fff; }
.btn-primary:hover { color: #fff; opacity: 0.92; transform: translateY(-1px); }
.btn-secondary { background: transparent; color: var(--asd-text); border-color: var(--asd-border-strong); }
.btn-secondary:hover { background: var(--asd-surface); color: var(--asd-text); }
.ripple { position: absolute; border-radius: 50%; background: rgba(255,255,255,0.4); transform: scale(0); animation: ripple 0.6s linear; pointer-events: none; }
@keyframes ripple { to { transform: scale(2.2); opacity: 0; } }

/* ---------- Sections ---------- */
section { padding: 4.5rem 0; }
.section-title { font-size: clamp(1.7rem, 3.4vw, 2.4rem); margin-bottom: 0.9rem; }
.section-subtitle { font-family: var(--sans); font-size: 1.05rem; color: var(--asd-text-2); max-width: 46rem; line-height: 1.75; }
.center { text-align: center; }
.center .section-subtitle { margin-left: auto; margin-right: auto; }
.surface-2 { background: var(--asd-surface-2); border-top: 0.5px solid var(--asd-border); border-bottom: 0.5px solid var(--asd-border); }

/* ---------- Hero ---------- */
.hero { padding: 5.5rem 0 4.5rem; }
.hero .eyebrow { margin-bottom: 1.1rem; display: inline-block; }
.hero-title {
	font-family: var(--serif); font-weight: 400;
	font-size: clamp(2.5rem, 6vw, 4.1rem); line-height: 1.08; color: var(--asd-text); margin-bottom: 1.3rem; max-width: 16ch;
}
.hero-title em { font-style: italic; color: var(--asd-sage-deep); }
.hero-subtitle { font-family: var(--sans); font-size: 1.15rem; color: var(--asd-text-2); max-width: 40rem; line-height: 1.75; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 2rem; }
.trust-badges { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 2.5rem; }
.trust-badges .badge {
	font-family: var(--sans); font-size: 0.78rem; font-weight: 500; color: var(--asd-text-2);
	background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: 100px; padding: 0.35rem 0.9rem;
}

/* ---------- Stat grid (the gap) ---------- */
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 2.5rem; }
.stat { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.6rem; }
.stat .num { font-family: var(--serif); font-size: 2.5rem; font-weight: 500; color: var(--asd-sage-deep); line-height: 1; }
.stat .lbl { font-family: var(--sans); font-size: 0.92rem; color: var(--asd-text-2); margin-top: 0.7rem; line-height: 1.6; }

/* ---------- Relationship (patient <-> provider) ---------- */
.rel-grid { display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch; gap: 1.25rem; margin-top: 2.5rem; }
.rel-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.8rem; }
.rel-card h3 { font-size: 1.45rem; margin-bottom: 0.5rem; }
.rel-card .who { font-family: var(--sans); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 0.8rem; }
.rel-card p { font-family: var(--sans); font-size: 0.95rem; color: var(--asd-text-2); line-height: 1.7; }
.rel-card ul { list-style: none; margin-top: 1rem; display: flex; flex-direction: column; gap: 0.5rem; }
.rel-card li { font-family: var(--sans); font-size: 0.9rem; color: var(--asd-text-2); padding-left: 1.2rem; position: relative; }
.rel-card li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 6px; height: 6px; border-radius: 50%; background: var(--asd-sage); }
.rel-card.patient { border-top: 3px solid var(--asd-sage); }
.rel-card.patient .who { color: var(--asd-sage-deep); }
.rel-card.provider { border-top: 3px solid var(--asd-blue); }
.rel-card.provider .who { color: var(--asd-blue-deep); }
.rel-card.provider li::before { background: var(--asd-blue); }
.rel-link {
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.6rem;
	min-width: 132px; text-align: center;
}
.rel-link .orb {
	width: 60px; height: 60px; border-radius: 50%; background: var(--asd-clay-tile); color: var(--asd-clay-deep);
	display: flex; align-items: center; justify-content: center;
}
.rel-link .cap { font-family: var(--sans); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--asd-clay-deep); }
.rel-link .ln { font-family: var(--serif); font-size: 1.1rem; color: var(--asd-text); font-style: italic; }
.rel-kicker { font-family: var(--serif); font-style: italic; font-size: 1.4rem; color: var(--asd-text); margin-top: 2rem; text-align: center; }
.rel-kicker strong { color: var(--asd-sage-deep); font-weight: 600; font-style: normal; }

/* ---------- The loop: Intention / Insight / Integration ---------- */
.loop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 2.5rem; }
.loop-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.9rem; }
.loop-card .loop-icon { width: 48px; height: 48px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; margin-bottom: 1.1rem; }
.loop-card .tag { font-family: var(--sans); font-size: 0.7rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 0.3rem; }
.loop-card h3 { font-size: 1.6rem; margin-bottom: 0.6rem; }
.loop-card p { font-family: var(--sans); font-size: 0.95rem; color: var(--asd-text-2); line-height: 1.7; }
.accent-sage .loop-icon { background: var(--asd-sage-tile); color: var(--asd-sage); }
.accent-sage .tag { color: var(--asd-sage-deep); }
.accent-blue .loop-icon { background: var(--asd-blue-tile); color: var(--asd-blue); }
.accent-blue .tag { color: var(--asd-blue-deep); }
.accent-clay .loop-icon { background: var(--asd-clay-tile); color: var(--asd-clay); }
.accent-clay .tag { color: var(--asd-clay-deep); }

/* ---------- Capabilities ---------- */
.cap-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.6rem 2.2rem; margin-top: 2.5rem; }
.cap-item { display: flex; gap: 1rem; }
.cap-icon { flex: 0 0 42px; width: 42px; height: 42px; border-radius: var(--radius-sm); background: var(--asd-sage-tile); color: var(--asd-sage); display: flex; align-items: center; justify-content: center; }
.cap-item h3 { font-family: var(--sans); font-size: 1.02rem; font-weight: 600; margin-bottom: 0.25rem; }
.cap-item p { font-family: var(--sans); font-size: 0.92rem; color: var(--asd-text-2); line-height: 1.65; }

/* ---------- Path tiles ---------- */
.path-tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-top: 2.5rem; }
.path-tile { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 2rem; display: block; transition: 0.2s; }
.path-tile:hover { transform: translateY(-3px); border-color: var(--asd-border-strong); }
.path-tile .path-tile-label { font-family: var(--sans); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--asd-sage-deep); margin-bottom: 0.6rem; }
.path-tile h3 { font-size: 1.5rem; margin-bottom: 0.4rem; color: var(--asd-text); }
.path-tile p { font-family: var(--sans); color: var(--asd-text-2); }

/* ---------- Testimonials ---------- */
.testimonials { background: var(--asd-surface-2); border-top: 0.5px solid var(--asd-border); border-bottom: 0.5px solid var(--asd-border); }
.testimonial-carousel { position: relative; max-width: 720px; margin: 2.5rem auto 0; overflow: hidden; }
.testimonial-track { display: flex; transition: transform 0.5s ease; }
.testimonial-card { min-width: 100%; padding: 0 1rem; text-align: center; }
.testimonial-text { font-family: var(--serif); font-style: italic; font-size: 1.4rem; line-height: 1.6; color: var(--asd-text); }
.testimonial-author { font-family: var(--sans); font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--asd-text-muted); margin-top: 1rem; }
.testimonial-avatar { font-size: 1.6rem; margin-bottom: 0.6rem; }
.carousel-controls { display: flex; justify-content: center; gap: 1rem; margin-top: 1.5rem; }
.carousel-btn { width: 40px; height: 40px; border-radius: 50%; border: 0.5px solid var(--asd-border-strong); background: var(--asd-surface); color: var(--asd-text-2); font-size: 1.3rem; cursor: pointer; line-height: 1; }
.carousel-btn:hover { background: var(--asd-active-bg); color: var(--asd-active-fg); }

/* ---------- FAQ ---------- */
.faq { max-width: 48rem; margin: 2rem auto 0; }
.faq h3 { font-family: var(--sans); font-size: 1.05rem; font-weight: 600; color: var(--asd-text); margin-top: 1.6rem; margin-bottom: 0.4rem; }
.faq p { font-family: var(--sans); font-size: 0.95rem; color: var(--asd-text-2); line-height: 1.7; }

/* ---------- Final CTA ---------- */
.cta-band { background: var(--asd-sage-tile); border-top: 0.5px solid var(--asd-border); border-bottom: 0.5px solid var(--asd-border); text-align: center; }
.cta-band .section-title { color: var(--asd-sage-deep); }
.cta-center { display: flex; justify-content: center; flex-wrap: wrap; gap: 0.85rem; margin-top: 1.8rem; }

/* ---------- Share strip ---------- */
.social-share-strip { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin-top: 2rem; }
.social-share-strip__label { font-family: var(--sans); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--asd-text-muted); }
.share-btn { font-family: var(--sans); font-size: 0.8rem; color: var(--asd-text-2); background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: 100px; padding: 0.35rem 0.85rem; cursor: pointer; }
.share-btn:hover { background: var(--asd-active-bg); color: var(--asd-active-fg); }

/* ---------- Footer ---------- */
.footer { background: var(--asd-surface-2); border-top: 0.5px solid var(--asd-border); padding: 3.5rem 0 2rem; }
.footer-content { display: grid; grid-template-columns: 1.6fr repeat(4, 1fr); gap: 2rem; }
.footer-section h3 { font-family: var(--serif); font-size: 1.3rem; color: var(--asd-sage-deep); margin-bottom: 0.7rem; }
.footer-section h4 { font-family: var(--sans); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--asd-text-muted); margin-bottom: 0.8rem; }
.footer-section p { font-family: var(--sans); font-size: 0.9rem; color: var(--asd-text-2); line-height: 1.7; max-width: 22rem; }
.footer-section ul { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.footer-section a { font-family: var(--sans); font-size: 0.9rem; color: var(--asd-text-2); }
.footer-section a:hover { color: var(--asd-sage-deep); }
.footer-bottom { border-top: 0.5px solid var(--asd-border); margin-top: 2.5rem; padding-top: 1.5rem; text-align: center; }
.footer-bottom p { font-family: var(--sans); font-size: 0.85rem; color: var(--asd-text-muted); }

/* ---------- Scroll fade-in ---------- */
.fade-in { opacity: 0; transform: translateY(16px); transition: opacity 0.6s ease, transform 0.6s ease; }
.fade-in.visible { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
	.nav-menu {
		position: fixed; inset: 66px 0 auto 0; flex-direction: column; gap: 0; background: var(--asd-canvas);
		border-bottom: 0.5px solid var(--asd-border); padding: 0.5rem 0; transform: translateY(-120%); transition: transform 0.3s ease; max-height: calc(100vh - 66px); overflow-y: auto;
	}
	.nav-menu.active { transform: translateY(0); }
	.nav-menu li { width: 100%; }
	.nav-menu a { display: block; padding: 0.9rem 1.5rem; }
	.hamburger { display: flex; }
	.nav-actions .btn-trial-nav { display: none; }
	.stat-grid, .loop-grid, .cap-grid, .path-tiles { grid-template-columns: 1fr; }
	.rel-grid { grid-template-columns: 1fr; }
	.rel-link { flex-direction: row; min-width: 0; }
	.rel-link .orb { transform: rotate(90deg); }
	.footer-content { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
	.footer-content { grid-template-columns: 1fr; }
	section { padding: 3.25rem 0; }
}

/* =========================================================================
   Legacy component compatibility — styles the existing markup on
   converted pages (blog, team, contact, pricing, legal) in the new palette.
   ========================================================================= */

/* Subpage hero */
.page-hero { padding: 3.5rem 0 1.5rem; }
.page-hero-content { max-width: var(--maxw); margin: 0 auto; padding: 0 1.5rem; }
.page-hero-title { font-family: var(--serif); font-weight: 400; font-size: clamp(2.2rem, 5vw, 3.4rem); line-height: 1.1; color: var(--asd-text); margin-bottom: 0.8rem; }
.page-hero-subtitle { font-family: var(--sans); font-size: 1.1rem; color: var(--asd-text-2); max-width: 44rem; line-height: 1.7; }

/* Alternating content sections */
.why-synergy { background: var(--asd-canvas); }
.core-features { background: var(--asd-surface-2); border-top: 0.5px solid var(--asd-border); border-bottom: 0.5px solid var(--asd-border); }
.why-synergy .container > h2, .core-features .container > h2 { margin-bottom: 0.8rem; }
.why-synergy .container > p, .core-features .container > p,
.page-hero ~ section .container > p { font-family: var(--sans); }
.content-columns h3, .container h3 { font-family: var(--serif); font-weight: 600; font-size: 1.3rem; color: var(--asd-text); }
.container ul li, .container ol li { color: var(--asd-text-2); }
.container ul li strong, .container p strong { color: var(--asd-text); }

/* Feature cards */
.feature-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.8rem; }
.feature-icon { width: 46px; height: 46px; border-radius: var(--radius-sm); background: var(--asd-sage-tile); color: var(--asd-sage); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; margin-bottom: 1rem; }
.feature-card h3 { font-family: var(--serif); font-size: 1.35rem; margin-bottom: 0.5rem; }
.feature-card p { color: var(--asd-text-2); }

/* Blog */
.blog-layout { display: grid; grid-template-columns: 1fr 300px; gap: 2.5rem; align-items: start; }
.blog-main { min-width: 0; }
.blog-sidebar { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.5rem; position: sticky; top: 90px; }
.blog-post-card, .blog-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.6rem; margin-bottom: 1.25rem; transition: 0.2s; }
.blog-post-card:hover, .blog-card:hover { border-color: var(--asd-border-strong); transform: translateY(-2px); }
.blog-post-title, .blog-card-title { font-family: var(--serif); font-size: 1.5rem; font-weight: 500; line-height: 1.2; margin-bottom: 0.5rem; }
.blog-post-title a, .blog-card-title a { color: var(--asd-text); }
.blog-post-title a:hover, .blog-card-title a:hover { color: var(--asd-sage-deep); }
.blog-post-meta { font-family: var(--sans); font-size: 0.8rem; color: var(--asd-text-muted); letter-spacing: 0.04em; margin-bottom: 0.7rem; }
.blog-post-excerpt, .blog-card-text { font-family: var(--sans); color: var(--asd-text-2); line-height: 1.7; }
.blog-post-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 1rem; }
.blog-post-tags span, .blog-post-tags a { font-size: 0.72rem; background: var(--asd-sage-tile); color: var(--asd-sage-deep); padding: 0.25rem 0.7rem; border-radius: 100px; }
.blog-callout { background: var(--asd-clay-tile); border-left: 3px solid var(--asd-clay); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; padding: 1.1rem 1.3rem; margin: 1.5rem 0; color: var(--asd-clay-deep); }

/* Blog article prose */
.blog-main h1 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
.blog-main h2 { font-size: 1.7rem; margin: 2rem 0 0.8rem; }
.blog-main h3 { font-size: 1.3rem; margin: 1.5rem 0 0.6rem; }
.blog-main p { margin-bottom: 1.1rem; color: var(--asd-text-2); line-height: 1.8; }
.blog-main ul, .blog-main ol { margin: 0 0 1.1rem 1.3rem; }
.blog-main li { margin-bottom: 0.5rem; color: var(--asd-text-2); line-height: 1.7; }
.blog-main blockquote { border-left: 3px solid var(--asd-sage); padding-left: 1.2rem; margin: 1.5rem 0; font-family: var(--serif); font-style: italic; font-size: 1.25rem; color: var(--asd-text); }
.blog-main img { max-width: 100%; height: auto; border-radius: var(--radius); }

/* Team */
.team-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.8rem; text-align: center; }
.team-photo { width: 110px; height: 110px; border-radius: 50%; object-fit: cover; margin: 0 auto 1rem; display: block; border: 0.5px solid var(--asd-border-strong); }
.team-name { font-family: var(--serif); font-size: 1.4rem; margin-bottom: 0.2rem; }
.team-role { font-family: var(--sans); font-size: 0.8rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--asd-sage-deep); margin-bottom: 0.8rem; }
.team-bio { font-family: var(--sans); font-size: 0.92rem; color: var(--asd-text-2); line-height: 1.7; text-align: left; }
.team-bio.collapsed { display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
.team-bio.expanded { display: block; }
.team-links { display: flex; gap: 0.8rem; justify-content: center; margin-top: 0.9rem; }
.read-more-btn { background: none; border: none; color: var(--asd-sage-deep); font-family: var(--sans); font-weight: 600; font-size: 0.85rem; cursor: pointer; padding: 0; margin-top: 0.6rem; }

/* Pricing */
.pricing-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 2rem; text-align: center; }
.price-amount { font-family: var(--serif); font-size: 2.6rem; font-weight: 500; color: var(--asd-sage-deep); }
.price-desc { font-family: var(--sans); color: var(--asd-text-2); margin-bottom: 1rem; }
.price-features { list-style: none; text-align: left; margin: 1.2rem 0; display: flex; flex-direction: column; gap: 0.55rem; }
.price-features li { font-family: var(--sans); font-size: 0.92rem; color: var(--asd-text-2); padding-left: 1.4rem; position: relative; }
.price-features li::before { content: "✓"; position: absolute; left: 0; color: var(--asd-sage); font-weight: 700; }
.btn-pricing { display: inline-flex; align-items: center; justify-content: center; background: var(--asd-send); color: #fff; font-family: var(--sans); font-weight: 600; padding: 0.8rem 1.6rem; border-radius: 100px; border: none; cursor: pointer; }
.btn-pricing:hover { color: #fff; opacity: 0.92; }

/* Accordion */
.accordion-item { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius-sm); margin-bottom: 0.8rem; overflow: hidden; }
.accordion-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 1.3rem; cursor: pointer; }
.accordion-title { font-family: var(--serif); font-size: 1.15rem; color: var(--asd-text); }
.accordion-arrow, .accordion-icon { color: var(--asd-sage); transition: transform 0.25s; }
.accordion-item.active .accordion-arrow { transform: rotate(180deg); }
.accordion-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; padding: 0 1.3rem; }
.accordion-item.active .accordion-content { max-height: 1000px; padding: 0 1.3rem 1.2rem; }
.accordion-content p, .accordion-content li { color: var(--asd-text-2); }

/* Forms (contact) */
.form-group { margin-bottom: 1.1rem; }
.form-group label { display: block; font-family: var(--sans); font-size: 0.85rem; font-weight: 600; color: var(--asd-text); margin-bottom: 0.4rem; }
.form-group input, .form-group textarea, .form-group select {
	width: 100%; font-family: var(--sans); font-size: 0.95rem; color: var(--asd-text);
	background: var(--asd-field); border: 0.5px solid var(--asd-border-strong); border-radius: var(--radius-sm); padding: 0.7rem 0.9rem;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--asd-sage); box-shadow: 0 0 0 3px var(--asd-sage-tile); }
.contact-detail { font-family: var(--sans); color: var(--asd-text-2); margin-bottom: 0.6rem; }

/* Follow / share misc */
.share-buttons { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.follow-form { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.follow-form input { flex: 1; min-width: 180px; background: var(--asd-field); border: 0.5px solid var(--asd-border-strong); border-radius: 100px; padding: 0.6rem 1rem; font-family: var(--sans); }
.follow-links { display: flex; gap: 0.8rem; flex-wrap: wrap; margin-top: 0.8rem; }

/* Generic content cards grid helper (legacy) */
.features-grid, .feature-grid, .card-grid, .pricing-grid, .team-grid, .blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; margin-top: 2rem; }

@media (max-width: 860px) {
	.blog-layout { grid-template-columns: 1fr; }
	.blog-sidebar { position: static; }
}

/* ---------- Sovereign Circuit highlight (How it works) ---------- */
.space-highlight {
	margin-top: 2.5rem;
	display: flex;
	align-items: center;
	gap: 1.6rem;
	flex-wrap: wrap;
	background: var(--asd-surface);
	border: 0.5px solid var(--asd-border);
	border-left: 3px solid var(--asd-clay);
	border-radius: var(--radius);
	padding: 1.8rem 2rem;
}
.space-highlight__icon {
	flex: 0 0 56px; width: 56px; height: 56px;
	border-radius: var(--radius);
	background: var(--asd-clay-tile); color: var(--asd-clay);
	display: flex; align-items: center; justify-content: center;
}
.space-highlight__body { flex: 1; min-width: 260px; }
.space-highlight__body .tag { font-family: var(--sans); font-size: 0.7rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 0.35rem; }
.space-highlight__body h3 { font-size: 1.55rem; margin-bottom: 0.5rem; }
.space-highlight__body p { font-family: var(--sans); color: var(--asd-text-2); line-height: 1.7; max-width: 50rem; }
.space-highlight__body a { color: var(--asd-clay-deep); font-weight: 600; text-decoration: underline; }
.space-highlight__cta { flex: 0 0 auto; }
@media (max-width: 600px) { .space-highlight__cta { width: 100%; } .space-highlight__cta .btn-secondary { width: 100%; justify-content: center; } }

/* ---------- How-it-works foundation line ---------- */
.how-foundation {
	margin-top: 2.25rem;
	text-align: center;
	font-family: var(--sans);
	font-size: 1.02rem;
	color: var(--asd-text-2);
}
.how-foundation a { color: var(--asd-sage-deep); font-weight: 600; text-decoration: underline; }

/* ---------- Patient Data Sovereignty ---------- */
.pds-band { background: var(--asd-sage-tile); border-top: 0.5px solid var(--asd-border); border-bottom: 0.5px solid var(--asd-border); }
.pds-head { display: flex; gap: 1rem; align-items: center; margin-bottom: 1.1rem; }
.pds-shield {
	flex: 0 0 56px; width: 56px; height: 56px; border-radius: var(--radius);
	background: var(--asd-surface); color: var(--asd-sage-deep);
	border: 0.5px solid var(--asd-border);
	display: flex; align-items: center; justify-content: center;
}
.pds-band .section-subtitle { color: var(--asd-text); max-width: 50rem; }
.pds-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 2.5rem; }
.pds-card { background: var(--asd-surface); border: 0.5px solid var(--asd-border); border-radius: var(--radius); padding: 1.7rem; }
.pds-card h3 { font-size: 1.3rem; margin-bottom: 0.5rem; color: var(--asd-text); }
.pds-card p { font-family: var(--sans); color: var(--asd-text-2); line-height: 1.7; }
@media (max-width: 860px) { .pds-grid { grid-template-columns: 1fr; } }
