/* ==========================================================================
   HAPPYPIP — Dosing & Onset Timeline Chart
   ========================================================================== */

.hp-dosing-chart {
	max-width: 900px;
	margin: 0 auto;
	padding: 60px 48px 80px;
}

/* ── Header ── */
.hp-dosing-chart__header {
	text-align: center;
	margin-bottom: var(--space-xl);
}

.hp-dosing-chart__eyebrow {
	font-family: var(--font-heading);
	font-size: var(--text-label);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--sunset-text);
	margin-bottom: var(--space-sm);
}

.hp-dosing-chart__title {
	font-family: var(--font-heading);
	font-size: var(--text-h1);
	font-weight: 700;
	color: var(--green-dark);
	margin: 0 0 var(--space-sm);
}

.hp-dosing-chart__subtitle {
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--text-muted);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.6;
}

/* ── Method Toggles ── */
.hp-dosing-chart__toggles {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-sm);
	margin-bottom: var(--space-xl);
}

.hp-dosing-chart__toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	border-radius: var(--radius-full);
	border: 1.5px solid var(--border-default);
	background: var(--bg-card);
	font-family: var(--font-heading);
	font-size: var(--text-small);
	font-weight: 600;
	color: var(--text-secondary);
	cursor: pointer;
	transition: all 0.2s ease;
}

.hp-dosing-chart__toggle:hover {
	border-color: var(--sunset-mid);
	color: var(--sunset-text);
}

.hp-dosing-chart__toggle.is-active {
	background: var(--green-deep);
	border-color: var(--green-deep);
	color: #FAF6EF;
}

.hp-dosing-chart__toggle-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* ── Chart Container ── */
.hp-dosing-chart__container {
	position: relative;
	background: #fff;
	border: 1px solid var(--border-default);
	border-radius: var(--radius-lg);
	padding: var(--space-lg) var(--space-md) var(--space-md) var(--space-md);
	margin-bottom: var(--space-xl);
	box-shadow: 0 4px 20px rgba(200, 165, 100, 0.08);
}

.hp-dosing-chart__container canvas {
	display: block;
}


/* ── Dosing Table ── */
.hp-dosing-chart__table-section {
	margin-bottom: var(--space-2xl);
}

.hp-dosing-chart__section-title {
	font-family: var(--font-heading);
	font-size: var(--text-h3);
	font-weight: 700;
	color: var(--green-dark);
	margin: 0 0 var(--space-lg);
	text-align: center;
}

.hp-dosing-chart__table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.hp-dosing-chart__table {
	width: 100%;
	border-collapse: collapse;
	background: var(--bg-card);
	border: 1px solid var(--border-default);
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.hp-dosing-chart__table th {
	font-family: var(--font-heading);
	font-size: var(--text-small);
	font-weight: 700;
	color: #FAF6EF;
	background: var(--green-deep);
	padding: 14px 18px;
	text-align: left;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.hp-dosing-chart__table td {
	font-family: var(--font-body);
	font-size: var(--text-sub);
	color: var(--text-body);
	padding: 14px 18px;
	border-bottom: 1px solid var(--border-default);
}

.hp-dosing-chart__table tbody tr:last-child td {
	border-bottom: none;
}

.hp-dosing-chart__table tbody tr:hover {
	background: var(--bg-surface);
}

.hp-dosing-chart__level {
	display: inline-block;
	padding: 3px 10px;
	border-radius: var(--radius-full);
	font-family: var(--font-heading);
	font-size: var(--text-badge);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.hp-dosing-chart__level--micro {
	background: #E4F2F0;
	color: #2A6A5A;
}

.hp-dosing-chart__level--beginner {
	background: #E8F0E4;
	color: #3A6A3A;
}

.hp-dosing-chart__level--standard {
	background: #FFF3D6;
	color: #B8860B;
}

.hp-dosing-chart__level--experienced {
	background: #F0E0F4;
	color: #7B3F8A;
}

/* ── Sources ── */
.hp-dosing-chart__sources {
	background: var(--bg-surface);
	border: 1px solid var(--border-default);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	margin-bottom: var(--space-xl);
}

.hp-dosing-chart__sources-title {
	font-family: var(--font-heading);
	font-size: var(--text-sub);
	font-weight: 700;
	color: var(--green-dark);
	margin: 0 0 var(--space-sm);
}

.hp-dosing-chart__sources ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.hp-dosing-chart__sources li {
	font-family: var(--font-body);
	font-size: var(--text-small);
	color: var(--text-muted);
	line-height: 1.6;
	padding-left: 16px;
	position: relative;
	margin-bottom: 6px;
}

.hp-dosing-chart__sources li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 8px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--sunset-mid);
}

.hp-dosing-chart__sources em {
	font-style: italic;
}

/* ── CTA ── */
.hp-dosing-chart__cta {
	display: flex;
	justify-content: center;
	gap: var(--space-md);
	flex-wrap: wrap;
}

/* ── Responsive ── */
@media (max-width: 768px) {
	.hp-dosing-chart {
		padding: 48px 32px 60px;
	}

	.hp-dosing-chart__legend {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 540px) {
	.hp-dosing-chart {
		padding: 36px 20px 48px;
	}

	.hp-dosing-chart__toggles {
		gap: 6px;
	}

	.hp-dosing-chart__toggle {
		padding: 6px 12px;
		font-size: var(--text-badge);
	}

	.hp-dosing-chart__container {
		padding: var(--space-md) var(--space-sm);
	}

	.hp-dosing-chart__y-label {
		display: none;
	}

	.hp-dosing-chart__table th,
	.hp-dosing-chart__table td {
		padding: 10px 12px;
		font-size: var(--text-small);
	}

	.hp-dosing-chart__cta {
		flex-direction: column;
		align-items: center;
	}
}
