/* Boldorg — Quote tool styles (uses theme tokens when present) */
.bo-quote {
	--q-blue: var(--bo-blue, #2563EB);
	--q-border: var(--bo-border, #E5E8EC);
	--q-ink: var(--bo-ink, #0E1116);
	--q-text: var(--bo-text, #5B6470);
	background: #fff;
	border: 1px solid var(--q-border);
	border-radius: var(--bo-r-lg, 24px);
	box-shadow: var(--bo-shadow-lg, 0 28px 64px rgba(14,17,22,.12));
	padding: clamp(1.5rem, 4vw, 3rem);
	max-width: 820px;
	margin: 0 auto;
}
.bo-quote__progress {
	height: 8px;
	border-radius: 999px;
	background: var(--bo-bg-soft, #F1F5FF);
	overflow: hidden;
}
.bo-quote__progress-bar {
	height: 100%;
	background: var(--bo-blue, #2563EB);
	border-radius: 999px;
	transition: width .45s cubic-bezier(.16,1,.3,1);
}
.bo-quote__meta {
	margin: .9rem 0 1rem;
	font-size: .8125rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--q-blue);
}
.bo-quote__error {
	margin: 0 0 1.25rem;
	padding: .75rem 1rem;
	border-radius: 12px;
	background: #FEF2F2;
	border: 1px solid #FECACA;
	color: #B91C1C;
	font-size: .9rem;
	font-weight: 500;
	line-height: 1.45;
}
.bo-quote__error[hidden] { display: none !important; }
.bo-quote__step { display: none; border: 0; padding: 0; margin: 0; }
.bo-quote__step.is-active { display: block; animation: boQuoteIn .45s cubic-bezier(.16,1,.3,1); }
@keyframes boQuoteIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.bo-quote__q {
	font-family: var(--bo-font-display, sans-serif);
	font-size: clamp(1.35rem, 2.6vw, 1.9rem);
	font-weight: 700;
	color: var(--q-ink);
	line-height: 1.2;
	padding: 0;
}
.bo-quote__sub { color: var(--q-text); margin: .5rem 0 1.6rem; }
.bo-quote__options { display: grid; grid-template-columns: repeat(2, 1fr); gap: .9rem; }
@media (max-width: 600px) { .bo-quote__options { grid-template-columns: 1fr; } }
.bo-quote__opt { cursor: pointer; }
.bo-quote__opt input { position: absolute; opacity: 0; pointer-events: none; }
.bo-quote__opt-inner {
	display: flex;
	align-items: center;
	gap: .9rem;
	padding: 1.1rem 1.2rem;
	border: 1.5px solid var(--q-border);
	border-radius: var(--bo-r-md, 16px);
	transition: border-color .2s, box-shadow .2s, transform .2s, background .2s;
	height: 100%;
	background: #fff;
}
.bo-quote__opt:hover .bo-quote__opt-inner { border-color: var(--bo-blue-300, #93C5FD); transform: translateY(-2px); }
.bo-quote__opt-icon {
	flex: 0 0 auto;
	width: 46px; height: 46px;
	display: grid; place-items: center;
	border-radius: 12px;
	background: var(--bo-blue-100, #EFF6FF);
	color: var(--q-blue);
	transition: background .2s, color .2s;
}
.bo-quote__opt-text { flex: 1; }
.bo-quote__opt-text strong { display: block; color: var(--q-ink); font-weight: 600; }
.bo-quote__opt-text small { color: var(--q-text); font-size: .85rem; line-height: 1.35; }
.bo-quote__opt-check {
	flex: 0 0 auto;
	width: 24px; height: 24px;
	border-radius: 50%;
	border: 1.5px solid var(--q-border);
	display: grid; place-items: center;
	color: #fff;
	opacity: 0;
	transition: opacity .2s, background .2s;
}
.bo-quote__opt input:checked + .bo-quote__opt-inner {
	border-color: var(--q-blue);
	box-shadow: 0 0 0 3px rgba(37,99,235,.12);
	background: var(--bo-blue-100, #EFF6FF);
}
.bo-quote__opt input:checked + .bo-quote__opt-inner .bo-quote__opt-icon { background: var(--q-blue); color: #fff; }
.bo-quote__opt input:checked + .bo-quote__opt-inner .bo-quote__opt-check { opacity: 1; background: var(--q-blue); border-color: var(--q-blue); }
.bo-quote__opt input:focus-visible + .bo-quote__opt-inner { outline: 2px solid var(--q-blue); outline-offset: 2px; }

.bo-quote__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 600px) { .bo-quote__grid { grid-template-columns: 1fr; } }
.bo-quote__grid label, .bo-quote__full {
	display: flex; flex-direction: column; gap: .4rem;
	font-size: .9rem; font-weight: 600; color: var(--q-ink);
}
.bo-quote__full { margin-top: 1rem; }
.bo-quote input[type="text"], .bo-quote input[type="email"], .bo-quote input[type="tel"], .bo-quote textarea {
	font: inherit; font-weight: 400;
	padding: .85rem 1rem;
	border: 1.5px solid var(--q-border);
	border-radius: 12px;
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
}
.bo-quote input:focus, .bo-quote textarea:focus {
	outline: none; border-color: var(--q-blue);
	box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.bo-quote textarea { resize: vertical; min-height: 6rem; }
.bo-quote__hp { position: absolute !important; left: -9999px !important; }
/* Buton görünürlüğü tamamen [hidden] ile yönetilir; .bo-btn display kuralını ezmesini engelle. */
.bo-quote [hidden] { display: none !important; }
.bo-quote__nav { display: flex; gap: .8rem; justify-content: space-between; align-items: center; margin-top: 2rem; flex-wrap: wrap; }
.bo-quote__nav .bo-btn--primary { margin-left: auto; }
@media (max-width: 480px) {
	.bo-quote__nav .bo-btn { flex: 1 1 calc(50% - .4rem); justify-content: center; }
	.bo-quote__nav .bo-btn--primary { margin-left: 0; }
}
.bo-quote__step.is-invalid .bo-quote__options { animation: boShake .4s; }
.bo-quote__step.is-invalid input:required:invalid,
.bo-quote__step.is-invalid input[name="email"]:invalid { border-color: var(--bo-red, #EF4444); }
@keyframes boShake { 0%,100%{transform:none} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }

.bo-quote.is-complete {
	padding-block: clamp(2rem, 5vw, 3.5rem);
}
.bo-quote__success {
	text-align: center;
	padding: clamp(1.5rem, 4vw, 2.5rem) 0 .5rem;
}
.bo-quote__success-icon {
	color: var(--bo-green, #16A34A);
	display: flex;
	justify-content: center;
	margin-bottom: 1.25rem;
}
.bo-quote__success-icon svg {
	width: 56px;
	height: 56px;
}
.bo-quote__success h3 {
	font-family: var(--bo-font-display, sans-serif);
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	color: var(--q-ink);
	margin-bottom: .35rem;
}
.bo-quote__success p {
	color: var(--q-text);
	max-width: 480px;
	margin: 0 auto;
	line-height: 1.65;
}
.bo-quote__success-actions {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	justify-content: center;
	margin-top: 1.75rem;
}
.bo-quote__success-actions .bo-btn {
	min-width: min(100%, 220px);
	justify-content: center;
}
