.wll-ttc-widget {
	box-sizing: border-box;
	margin: 1.25em 0;
	padding: 1em 1.618em;
	background: #ffffff;
	border: 1px solid #d6e6cc;
	border-left: 0.4180469716em solid #4a7c2a;
	border-radius: 4px;
	color: #1f2a17;
	font-size: 0.95em;
	line-height: 1.5;
}

.wll-ttc-widget *,
.wll-ttc-widget *::before,
.wll-ttc-widget *::after {
	box-sizing: inherit;
}

.wll-ttc-header {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5em;
	margin-bottom: 0.625em;
}

.wll-ttc-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: #f0f7eb;
	color: #2e6b1e;
}

.wll-ttc-icon svg {
	display: block;
	width: 20px;
	height: 20px;
}

.wll-ttc-title {
	flex: 1 1 auto;
	font-weight: 600;
	color: #1f2a17;
	font-size: 1em;
	line-height: 1.3;
}

.wll-ttc-momentum {
	font-weight: 400;
	color: #5a6750;
	font-size: 0.85em;
	margin-left: 0.25em;
}

.wll-ttc-optional {
	flex-shrink: 0;
	display: inline-block;
	padding: 0.18em 0.55em;
	background: #f0f7eb;
	color: #2e6b1e;
	border: 1px solid #cfe2c2;
	border-radius: 999px;
	font-size: 0.7em;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.4;
	white-space: nowrap;
}

.wll-ttc-action {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5em 0.75em;
	margin: 0 0 0.625em;
}

.wll-ttc-checkbox {
	display: flex;
	align-items: center;
	gap: 0.5em;
	cursor: pointer;
	margin: 0;
	flex: 0 0 auto;
}

.wll-ttc-checkbox input[type="checkbox"] {
	margin: 0;
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	accent-color: #4a7c2a;
	cursor: pointer;
}

.wll-ttc-checkbox input[type="checkbox"]:focus-visible {
	outline: 2px solid #4a7c2a;
	outline-offset: 2px;
}

.wll-ttc-checkbox-text {
	font-weight: 500;
	color: #1f2a17;
}

.wll-ttc-amounts {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em;
	flex: 0 1 auto;
}

.wll-ttc-amounts[data-disabled="true"] {
	opacity: 0.5;
}

.wll-ttc-amount {
	display: flex;
	align-items: center;
	gap: 0.35em;
	padding: 0.35em 0.6em;
	border: 1px solid #d6e6cc;
	border-radius: 6px;
	background: #ffffff;
	color: #1f2a17;
	cursor: pointer;
	font-weight: 500;
	transition: background-color 200ms ease, border-color 200ms ease;
	flex: 0 0 auto;
}

.wll-ttc-amount:hover {
	background: #fafdf7;
	border-color: #b9d4a8;
}

.wll-ttc-amount input[type="radio"] {
	margin: 0;
	width: 14px;
	height: 14px;
	accent-color: #4a7c2a;
	cursor: pointer;
}

.wll-ttc-amount input[type="radio"]:focus-visible {
	outline: 2px solid #4a7c2a;
	outline-offset: 2px;
}

.wll-ttc-amount-label {
	white-space: nowrap;
}

.wll-ttc-amount-fraction {
	font-size: 0.85em;
	color: #5a6750;
	font-weight: 400;
	margin-left: 0.15em;
}

.wll-ttc-amount.is-selected {
	background: #f0f7eb;
	border-color: #4a7c2a;
	color: #1f2a17;
}

.wll-ttc-amount-select-wrap {
	display: none;
	flex: 1 1 auto;
	min-width: 0;
}

.wll-ttc-amount-select {
	width: 100%;
	padding: 0.5em 0.6em;
	border-radius: 6px;
	border: 1px solid #d6e6cc;
	background: #ffffff;
	color: #1f2a17;
	font-size: 1em;
	font-family: inherit;
	cursor: pointer;
}

@media (hover: hover) and (pointer: fine) and (min-width: 481px) {
	.wll-ttc-amount {
		position: relative;
	}

	.wll-ttc-amount[data-tooltip]:hover::after {
		content: attr(data-tooltip);
		position: absolute;
		bottom: calc(100% + 6px);
		left: 50%;
		transform: translateX(-50%);
		padding: 0.4em 0.6em;
		background: #1f2a17;
		color: #ffffff;
		border-radius: 4px;
		font-size: 0.78em;
		line-height: 1.3;
		white-space: nowrap;
		pointer-events: none;
		z-index: 10;
		box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
	}

	.wll-ttc-amount[data-tooltip]:hover::before {
		content: "";
		position: absolute;
		bottom: calc(100% + 2px);
		left: 50%;
		transform: translateX(-50%);
		border: 4px solid transparent;
		border-top-color: #1f2a17;
		pointer-events: none;
		z-index: 10;
	}
}

.wll-ttc-info {
	margin: 0;
	color: #2f3b27;
	font-size: 0.92em;
	line-height: 1.45;
}

.wll-ttc-social-proof {
	display: inline;
}

.wll-ttc-region-line {
	display: inline;
	transition: opacity 200ms ease;
}

.wll-ttc-social-proof + .wll-ttc-region-line::before {
	content: " ";
}

.wll-ttc-accordion {
	margin: 0.5em 0 0;
}

.wll-ttc-accordion-summary {
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	padding: 0.2em 0;
	color: #2e6b1e;
	font-size: 0.82em;
	font-weight: 500;
	list-style: none;
	user-select: none;
	border-radius: 4px;
}

.wll-ttc-accordion-summary::-webkit-details-marker {
	display: none;
}

.wll-ttc-accordion-summary::before {
	content: "";
	display: inline-block;
	width: 0;
	height: 0;
	border-left: 5px solid currentColor;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	transition: transform 200ms ease;
	transform-origin: 25% 50%;
}

.wll-ttc-accordion[open] > .wll-ttc-accordion-summary::before {
	transform: rotate(90deg);
}

.wll-ttc-accordion-summary:hover {
	color: #4a7c2a;
	text-decoration: underline;
}

.wll-ttc-accordion-summary:focus-visible {
	outline: 2px solid #4a7c2a;
	outline-offset: 2px;
}

.wll-ttc-accordion-body {
	padding-top: 0.45em;
	color: #5a6750;
	font-size: 0.85em;
	line-height: 1.5;
}

.wll-ttc-accordion-body p {
	margin: 0 0 0.5em;
}

.wll-ttc-accordion-body p:last-child {
	margin-bottom: 0;
}

.wll-ttc-fee-icon {
	vertical-align: middle;
	margin-right: 0.4em;
}

.wll-ttc-stats {
	font-size: 0.95em;
	line-height: 1.5;
}

.wll-ttc-stats p {
	margin: 0 0 0.5em;
}

.wll-ttc-combined .wll-ttc-intro {
	font-size: 1.2em;
	font-weight: 600;
	text-align: center;
	margin: 0 0 1.25em;
	color: #2e6b1e;
}

.wll-ttc-combined .wll-ttc-era {
	margin: 0.75em 0;
	padding: 0.75em 1em;
	border-left: 3px solid #cfe2c2;
	background: #f8fbf6;
	border-radius: 0 4px 4px 0;
}

.wll-ttc-combined .wll-ttc-era-label {
	display: block;
	font-size: 0.78em;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #4a7c2a;
	margin-bottom: 0.35em;
}

.wll-ttc-combined .wll-ttc-era p {
	margin: 0;
}

.wll-ttc-combined .wll-ttc-bridge {
	margin: 1.25em 0 0;
	padding-top: 1em;
	border-top: 1px solid #e0e8d6;
	font-style: italic;
	text-align: center;
	color: #4a7c2a;
}

@media (prefers-reduced-motion: reduce) {
	.wll-ttc-checkbox,
	.wll-ttc-amount,
	.wll-ttc-region-line,
	.wll-ttc-accordion-summary::before {
		transition: none;
	}
}

@media (max-width: 480px) {
	.wll-ttc-widget {
		padding: 0.85em 1em;
	}

	.wll-ttc-header {
		gap: 0.4em;
	}

	.wll-ttc-icon {
		width: 28px;
		height: 28px;
	}

	.wll-ttc-icon svg {
		width: 18px;
		height: 18px;
	}

	.wll-ttc-title {
		flex: 1 1 0;
		min-width: 0;
		font-size: 0.95em;
	}

	.wll-ttc-optional {
		font-size: 0.65em;
	}

	.wll-ttc-amounts {
		display: none;
	}

	.wll-ttc-amount-select-wrap {
		display: block;
	}
}
