
	.add-page.svelte-j15r9w {
		display: flex;
		flex-direction: column;
	}

	.page-header.svelte-j15r9w {
		margin-bottom: 18px;
	}

	.page-header.svelte-j15r9w h1:where(.svelte-j15r9w) {
		font-size: 1.4rem;
		font-weight: 800;
		color: var(--text);
		letter-spacing: -0.02em;
		margin: 0 0 4px;
	}

	.subtitle.svelte-j15r9w {
		font-size: 0.88rem;
		color: var(--text-muted);
		margin: 0;
	}

	.error-banner.svelte-j15r9w {
		display: flex;
		align-items: center;
		gap: 8px;
		background: var(--danger-soft);
		color: #b91c1c;
		padding: 12px 14px;
		border-radius: var(--radius-sm);
		margin-bottom: 14px;
		font-size: 0.88rem;
		font-weight: 500;
		border: 1px solid #fecaca;
	}

	.card.svelte-j15r9w {
		background: var(--surface);
		border: 1px solid var(--border);
		border-radius: var(--radius-lg);
		padding: 16px;
		box-shadow: var(--shadow-sm);
	}

	.type-card.svelte-j15r9w {
		display: flex;
		flex-direction: column;
		gap: 10px;
		margin-bottom: 16px;
	}

	.card-label.svelte-j15r9w {
		font-size: 0.72rem;
		font-weight: 700;
		color: var(--text-muted);
		text-transform: uppercase;
		letter-spacing: 0.07em;
	}

	.type-grid.svelte-j15r9w {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}

	.type-option.svelte-j15r9w {
		display: flex;
		align-items: center;
		gap: 8px;
		padding: 11px 12px;
		border: 1.5px solid var(--border);
		border-radius: 10px;
		background: var(--surface);
		cursor: pointer;
		font-size: 0.9rem;
		font-weight: 600;
		color: var(--text);
		text-align: left;
		transition:
			border-color 0.15s,
			background 0.15s,
			color 0.15s;
	}

	.type-option.svelte-j15r9w:hover {
		border-color: var(--border-strong);
	}

	.type-option.selected.svelte-j15r9w {
		border-color: var(--brand);
		background: var(--brand-soft-2);
		color: var(--brand-strong);
	}

	.type-icon.svelte-j15r9w {
		color: var(--text-muted);
		display: inline-flex;
		flex-shrink: 0;
	}

	.type-option.selected.svelte-j15r9w .type-icon:where(.svelte-j15r9w) {
		color: var(--brand);
	}

	.library.svelte-j15r9w {
		display: flex;
		flex-direction: column;
		gap: 12px;
	}

	.library-header.svelte-j15r9w {
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: 10px;
	}

	.library-header.svelte-j15r9w h2:where(.svelte-j15r9w) {
		display: inline-flex;
		align-items: center;
		gap: 8px;
		font-size: 0.78rem;
		font-weight: 700;
		color: var(--text-muted);
		text-transform: uppercase;
		letter-spacing: 0.07em;
		margin: 0;
	}

	.library-header.svelte-j15r9w > div:where(.svelte-j15r9w) {
		display: inline-flex;
		align-items: center;
		gap: 8px;
	}

	.count.svelte-j15r9w {
		font-size: 0.7rem;
		background: var(--brand-soft);
		color: var(--brand-strong);
		padding: 1px 8px;
		border-radius: 999px;
		font-weight: 700;
	}

	.new-btn.svelte-j15r9w {
		display: inline-flex;
		align-items: center;
		gap: 6px;
		background: var(--brand);
		color: white;
		padding: 8px 12px;
		border-radius: 9px;
		text-decoration: none;
		font-size: 0.82rem;
		font-weight: 600;
		box-shadow: 0 2px 8px rgba(22, 163, 74, 0.3);
		transition: background 0.15s;
	}

	.new-btn.svelte-j15r9w:hover {
		background: var(--brand-strong);
	}

	.search.svelte-j15r9w input:where(.svelte-j15r9w) {
		width: 100%;
		padding: 11px 14px;
		border: 1.5px solid var(--border);
		border-radius: 10px;
		font-size: 0.9rem;
		font-family: inherit;
		background: var(--surface);
		color: var(--text);
		outline: none;
		transition:
			border-color 0.15s,
			box-shadow 0.15s;
		-webkit-appearance: none;
	}

	.search.svelte-j15r9w input:where(.svelte-j15r9w):focus {
		border-color: var(--brand);
		box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.15);
	}

	.no-match.svelte-j15r9w {
		text-align: center;
		font-size: 0.88rem;
		color: var(--text-muted);
		padding: 24px 12px;
		margin: 0;
	}

	.empty-state.svelte-j15r9w {
		display: flex;
		flex-direction: column;
		align-items: center;
		text-align: center;
		padding: 32px 16px;
		background: var(--surface);
		border: 1px dashed var(--border-strong);
		border-radius: var(--radius-lg);
	}

	.empty-icon.svelte-j15r9w {
		width: 56px;
		height: 56px;
		border-radius: 16px;
		background: var(--brand-soft);
		color: var(--brand-strong);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		margin-bottom: 14px;
	}

	.empty-title.svelte-j15r9w {
		margin: 0 0 4px;
		font-size: 1rem;
		font-weight: 700;
		color: var(--text);
	}

	.empty-text.svelte-j15r9w {
		margin: 0 0 18px;
		font-size: 0.88rem;
		color: var(--text-muted);
		max-width: 32ch;
	}

	.cta-btn.svelte-j15r9w {
		display: inline-flex;
		align-items: center;
		gap: 6px;
		background: var(--brand);
		color: white;
		text-decoration: none;
		padding: 11px 18px;
		border-radius: 10px;
		font-weight: 600;
		font-size: 0.9rem;
		box-shadow: 0 2px 8px rgba(22, 163, 74, 0.3);
	}

	.template-list.svelte-j15r9w {
		list-style: none;
		padding: 0;
		margin: 0;
		display: flex;
		flex-direction: column;
		gap: 8px;
	}

	.template-row.svelte-j15r9w {
		position: relative;
	}

	.log-form.svelte-j15r9w {
		margin: 0;
	}

	.template-card.svelte-j15r9w {
		width: 100%;
		display: flex;
		align-items: center;
		gap: 14px;
		padding: 12px 56px 12px 14px;
		background: var(--surface);
		border: 1px solid var(--border);
		border-radius: var(--radius-md);
		box-shadow: var(--shadow-sm);
		cursor: pointer;
		font: inherit;
		text-align: left;
		color: var(--text);
		transition:
			border-color 0.15s,
			transform 0.05s,
			box-shadow 0.15s;
	}

	.template-card.svelte-j15r9w:hover {
		border-color: var(--brand);
		box-shadow: 0 2px 10px rgba(22, 163, 74, 0.1);
	}

	.template-card.svelte-j15r9w:active {
		transform: scale(0.995);
	}

	.tpl-main.svelte-j15r9w {
		flex: 1;
		min-width: 0;
		display: flex;
		flex-direction: column;
		gap: 4px;
	}

	.tpl-name.svelte-j15r9w {
		font-size: 0.95rem;
		font-weight: 600;
		color: var(--text);
		letter-spacing: -0.01em;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.tpl-macros.svelte-j15r9w {
		display: flex;
		gap: 5px;
		flex-wrap: wrap;
	}

	.macro.svelte-j15r9w {
		font-size: 0.66rem;
		font-weight: 600;
		padding: 2px 7px;
		border-radius: 6px;
	}

	.macro.p.svelte-j15r9w {
		background: var(--protein-soft);
		color: var(--protein);
	}

	.macro.c.svelte-j15r9w {
		background: var(--carbs-soft);
		color: #b45309;
	}

	.macro.f.svelte-j15r9w {
		background: var(--fat-soft);
		color: var(--fat);
	}

	.tpl-right.svelte-j15r9w {
		display: flex;
		align-items: center;
		gap: 10px;
		flex-shrink: 0;
	}

	.tpl-cal.svelte-j15r9w {
		font-size: 1rem;
		font-weight: 800;
		color: var(--text);
		letter-spacing: -0.02em;
		display: inline-flex;
		align-items: baseline;
		gap: 3px;
		white-space: nowrap;
	}

	.tpl-cal.svelte-j15r9w small:where(.svelte-j15r9w) {
		font-size: 0.65rem;
		color: var(--text-subtle);
		font-weight: 600;
	}

	.add-pill.svelte-j15r9w {
		width: 30px;
		height: 30px;
		border-radius: 999px;
		background: var(--brand-soft);
		color: var(--brand-strong);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		flex-shrink: 0;
		transition:
			background 0.15s,
			color 0.15s;
	}

	.template-card.svelte-j15r9w:hover .add-pill:where(.svelte-j15r9w) {
		background: var(--brand);
		color: white;
	}

	.edit-btn.svelte-j15r9w {
		position: absolute;
		top: 50%;
		right: 12px;
		transform: translateY(-50%);
		width: 30px;
		height: 30px;
		border-radius: 8px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		color: var(--text-subtle);
		text-decoration: none;
		transition:
			background 0.15s,
			color 0.15s;
		background: transparent;
		z-index: 1;
	}

	.edit-btn.svelte-j15r9w:hover {
		background: var(--surface-2);
		color: var(--text);
	}

	@media (min-width: 900px) {
		.page-header.svelte-j15r9w h1:where(.svelte-j15r9w) {
			font-size: 1.7rem;
		}

		.subtitle.svelte-j15r9w {
			font-size: 0.95rem;
		}

		.type-grid.svelte-j15r9w {
			grid-template-columns: repeat(4, 1fr);
		}

		.template-card.svelte-j15r9w {
			padding: 14px 56px 14px 18px;
		}
	}
