/* Bookinia — widget de reservas. Todo scopeado a .bookinia-widget. */

.bookinia-widget {
	--bk-primary: #2f6bff;
	--bk-dark: #0b1b3a;
	--bk-bg: #ffffff;
	--bk-soft: #f5f7fb;
	--bk-line: #e3e8f2;
	--bk-muted: #6b7691;
	--bk-radius: 16px;
	--bk-shadow: 0 12px 40px rgba(11, 27, 58, 0.10);

	box-sizing: border-box;
	max-width: 880px;
	margin: 0 auto;
	background: var(--bk-bg);
	color: var(--bk-dark);
	border: 1px solid var(--bk-line);
	border-radius: var(--bk-radius);
	box-shadow: var(--bk-shadow);
	overflow: hidden;
	font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
}

.bookinia-widget *,
.bookinia-widget *::before,
.bookinia-widget *::after {
	box-sizing: border-box;
}

/* Página dedicada (link público de reserva). */
body.bookinia-standalone {
	margin: 0;
	background: var(--bk-soft, #f5f7fb);
}
.bookinia-page-wrap {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 32px 16px;
}

/* Cabecera. */
.bookinia-widget .bk-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 24px;
	background: var(--bk-dark);
}
.bookinia-widget .bk-logo { height: 30px; width: auto; display: block; }
.bookinia-widget .bk-logo-text {
	color: #fff;
	font-weight: 800;
	font-size: 20px;
	letter-spacing: -0.02em;
}
.bookinia-widget .bk-steps { display: flex; gap: 8px; }
.bookinia-widget .bk-dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: rgba(255, 255, 255, 0.25);
	transition: background 0.25s ease, transform 0.25s ease;
}
.bookinia-widget .bk-dot.is-active { background: var(--bk-primary); transform: scale(1.25); }
.bookinia-widget .bk-dot.is-done { background: rgba(255, 255, 255, 0.7); }

/* Cuerpo. */
.bookinia-widget .bk-body { padding: 28px 24px 32px; min-height: 360px; }
.bookinia-widget .bk-step-title {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 0 0 4px;
}
.bookinia-widget .bk-step-sub { color: var(--bk-muted); font-size: 14px; margin: 0 0 20px; }

/* Tarjetas de selección (profesional / servicio). */
.bookinia-widget .bk-cards { display: grid; gap: 12px; }
.bookinia-widget .bk-card {
	display: flex; align-items: center; gap: 14px;
	width: 100%; text-align: left;
	padding: 16px; border: 1px solid var(--bk-line);
	border-radius: 14px; background: #fff; cursor: pointer;
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}
.bookinia-widget .bk-card:hover { border-color: var(--bk-primary); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(47, 107, 255, 0.12); }
.bookinia-widget .bk-card:focus-visible { outline: 3px solid rgba(47, 107, 255, 0.35); outline-offset: 2px; }
.bookinia-widget .bk-avatar {
	width: 46px; height: 46px; border-radius: 50%;
	object-fit: cover; flex: 0 0 auto;
	background: var(--bk-soft);
	display: flex; align-items: center; justify-content: center;
	font-weight: 700; color: var(--bk-primary);
}
.bookinia-widget .bk-card-main { flex: 1; min-width: 0; }
.bookinia-widget .bk-card-name { font-weight: 650; font-size: 15px; }
.bookinia-widget .bk-card-meta { color: var(--bk-muted); font-size: 13px; margin-top: 2px; }
.bookinia-widget .bk-card-price { font-weight: 700; color: var(--bk-primary); font-size: 14px; white-space: nowrap; }
.bookinia-widget .bk-chev { color: var(--bk-muted); flex: 0 0 auto; }

/* Layout fecha + horas. */
.bookinia-widget .bk-schedule { display: grid; grid-template-columns: 1fr 240px; gap: 24px; }

/* Calendario. */
.bookinia-widget .bk-cal-head {
	display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px;
}
.bookinia-widget .bk-cal-title { font-weight: 700; font-size: 15px; text-transform: capitalize; }
.bookinia-widget .bk-cal-nav {
	border: 1px solid var(--bk-line); background: #fff; border-radius: 10px;
	width: 34px; height: 34px; cursor: pointer; color: var(--bk-dark);
	display: flex; align-items: center; justify-content: center;
	transition: border-color 0.15s ease, color 0.15s ease;
}
.bookinia-widget .bk-cal-nav:hover:not(:disabled) { border-color: var(--bk-primary); color: var(--bk-primary); }
.bookinia-widget .bk-cal-nav:disabled { opacity: 0.4; cursor: not-allowed; }
.bookinia-widget .bk-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.bookinia-widget .bk-cal-dow {
	text-align: center; font-size: 11px; font-weight: 600;
	color: var(--bk-muted); padding: 6px 0; text-transform: uppercase;
}
.bookinia-widget .bk-day {
	aspect-ratio: 1 / 1; border: none; background: transparent;
	border-radius: 10px; font-size: 14px; color: var(--bk-dark);
	cursor: pointer; font-weight: 500;
	transition: background 0.15s ease, color 0.15s ease;
}
.bookinia-widget .bk-day:hover:not(:disabled):not(.is-empty) { background: var(--bk-soft); }
.bookinia-widget .bk-day.is-available { color: var(--bk-primary); font-weight: 700; }
.bookinia-widget .bk-day.is-available::after {
	content: ""; display: block; width: 4px; height: 4px; border-radius: 50%;
	background: var(--bk-primary); margin: 2px auto 0;
}
.bookinia-widget .bk-day.is-selected { background: var(--bk-primary); color: #fff; }
.bookinia-widget .bk-day.is-selected::after { background: #fff; }
.bookinia-widget .bk-day:disabled, .bookinia-widget .bk-day.is-empty { color: #c2cadb; cursor: default; }

/* Columna de horarios. */
.bookinia-widget .bk-times { display: flex; flex-direction: column; }
.bookinia-widget .bk-times-label { font-weight: 700; font-size: 14px; margin-bottom: 10px; }
.bookinia-widget .bk-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; max-height: 320px; overflow-y: auto; padding-right: 2px; }
.bookinia-widget .bk-slot {
	padding: 11px 8px; border: 1px solid var(--bk-line); background: #fff;
	border-radius: 10px; font-weight: 650; font-size: 14px; color: var(--bk-dark);
	cursor: pointer; transition: all 0.15s ease;
}
.bookinia-widget .bk-slot:hover { border-color: var(--bk-primary); color: var(--bk-primary); }
.bookinia-widget .bk-slot.is-selected { background: var(--bk-primary); border-color: var(--bk-primary); color: #fff; }

/* Formulario. */
.bookinia-widget .bk-form { display: grid; gap: 14px; max-width: 480px; }
.bookinia-widget .bk-field { display: grid; gap: 6px; }
.bookinia-widget .bk-field label { font-size: 13px; font-weight: 600; }
.bookinia-widget .bk-field input,
.bookinia-widget .bk-field textarea,
.bookinia-widget .bk-field select {
	width: 100%; padding: 11px 13px; border: 1px solid var(--bk-line);
	border-radius: 10px; font-size: 14px; font-family: inherit; color: var(--bk-dark);
	background: #fff; transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.bookinia-widget .bk-field input:focus,
.bookinia-widget .bk-field textarea:focus,
.bookinia-widget .bk-field select:focus {
	outline: none; border-color: var(--bk-primary);
	box-shadow: 0 0 0 3px rgba(47, 107, 255, 0.15);
}
.bookinia-widget .bk-field.has-error input,
.bookinia-widget .bk-field.has-error textarea { border-color: #e0245e; }
.bookinia-widget .bk-field .bk-err { color: #e0245e; font-size: 12px; }
.bookinia-widget .bk-hp { position: absolute; left: -9999px; opacity: 0; height: 0; width: 0; }
.bookinia-widget .bk-modality { display: flex; gap: 10px; }
.bookinia-widget .bk-modality label {
	flex: 1; text-align: center; padding: 10px; border: 1px solid var(--bk-line);
	border-radius: 10px; cursor: pointer; font-weight: 600; font-size: 13px;
}
.bookinia-widget .bk-modality input { position: absolute; opacity: 0; }
.bookinia-widget .bk-modality input:checked + span { color: var(--bk-primary); }
.bookinia-widget .bk-modality label:has(input:checked) { border-color: var(--bk-primary); background: rgba(47,107,255,0.06); }

/* Resumen de reserva. */
.bookinia-widget .bk-summary {
	background: var(--bk-soft); border-radius: 12px; padding: 14px 16px;
	margin-bottom: 18px; font-size: 14px; display: grid; gap: 4px;
}
.bookinia-widget .bk-summary strong { font-weight: 700; }

/* Botonera. */
.bookinia-widget .bk-actions { display: flex; gap: 10px; margin-top: 22px; align-items: center; }
.bookinia-widget .bk-btn {
	appearance: none; border: none; cursor: pointer; font-family: inherit;
	font-weight: 700; font-size: 14px; padding: 12px 22px; border-radius: 11px;
	transition: transform 0.12s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.bookinia-widget .bk-btn--primary { background: var(--bk-primary); color: #fff; }
.bookinia-widget .bk-btn--primary:hover { box-shadow: 0 8px 22px rgba(47, 107, 255, 0.35); transform: translateY(-1px); }
.bookinia-widget .bk-btn--primary:disabled { opacity: 0.6; cursor: progress; transform: none; box-shadow: none; }
.bookinia-widget .bk-btn--ghost { background: transparent; color: var(--bk-muted); padding-left: 6px; padding-right: 6px; }
.bookinia-widget .bk-btn--ghost:hover { color: var(--bk-dark); }
.bookinia-widget .bk-btn--ghost-danger { background: transparent; border: 1px solid var(--bk-line); color: #e0245e; }
.bookinia-widget .bk-btn--ghost-danger:hover { border-color: #e0245e; }
.bookinia-widget .bk-spacer { flex: 1; }

/* Confirmación. */
.bookinia-widget .bk-done { text-align: center; padding: 30px 10px; }
.bookinia-widget .bk-check {
	width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 18px;
	background: rgba(47, 107, 255, 0.12); color: var(--bk-primary);
	display: flex; align-items: center; justify-content: center;
	animation: bk-pop 0.4s ease;
}
@keyframes bk-pop { 0% { transform: scale(0.6); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
.bookinia-widget .bk-done h2 { margin: 0 0 6px; font-size: 22px; letter-spacing: -0.02em; }
.bookinia-widget .bk-done p { color: var(--bk-muted); margin: 0 auto; max-width: 360px; }

/* Estados auxiliares. */
.bookinia-widget .bk-loading { display: flex; justify-content: center; padding: 60px 0; }
.bookinia-widget .bk-spinner {
	width: 32px; height: 32px; border-radius: 50%;
	border: 3px solid var(--bk-line); border-top-color: var(--bk-primary);
	animation: bk-spin 0.8s linear infinite;
}
@keyframes bk-spin { to { transform: rotate(360deg); } }
.bookinia-widget .bk-empty, .bookinia-widget .bk-no-slots { color: var(--bk-muted); text-align: center; padding: 32px 12px; font-size: 14px; }
.bookinia-widget .bk-error { color: #e0245e; font-size: 13px; margin-top: 10px; }

/* Notice / badges (gestión). */
.bookinia-widget .bk-notice { padding: 12px 16px; border-radius: 10px; font-size: 14px; margin-bottom: 16px; }
.bookinia-widget .bk-notice--ok { background: rgba(34, 197, 94, 0.12); color: #15803d; }
.bookinia-widget .bk-notice--err { background: rgba(224, 36, 94, 0.12); color: #be123c; }
.bookinia-widget .bk-pay-option.is-loading { opacity: 0.6; cursor: progress; }
.bookinia-widget .bk-manage-card { padding: 8px 4px; }
.bookinia-widget .bk-manage-title { margin: 10px 0 14px; font-size: 20px; }
.bookinia-widget .bk-detail { list-style: none; padding: 0; margin: 0 0 20px; display: grid; gap: 8px; font-size: 14px; }
.bookinia-widget .bk-badge { display: inline-block; padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; background: var(--bk-soft); }
.bookinia-widget .bk-badge--confirmed { background: rgba(34,197,94,0.14); color: #15803d; }
.bookinia-widget .bk-badge--pending { background: rgba(234,179,8,0.16); color: #a16207; }
.bookinia-widget .bk-badge--cancelled { background: rgba(224,36,94,0.12); color: #be123c; }

/* Responsive. */
@media (max-width: 640px) {
	.bookinia-widget .bk-schedule { grid-template-columns: 1fr; }
	.bookinia-widget .bk-slots { grid-template-columns: 1fr 1fr 1fr; max-height: none; }
	.bookinia-widget .bk-body { padding: 22px 16px 26px; }
}

@media (prefers-reduced-motion: reduce) {
	.bookinia-widget * { animation: none !important; transition: none !important; }
}

/* Extras y cupón */
.bk-extras label.bk-extra { display:flex; align-items:center; gap:10px; padding:9px 12px; border:1px solid var(--bk-line,#e3e8f2); border-radius:10px; margin-bottom:8px; cursor:pointer; font-weight:500; }
.bk-extras label.bk-extra:hover { border-color:#cfd9ee; }
.bk-extras .bk-extra-price { margin-left:auto; color:#2f6bff; font-weight:600; }
.bk-coupon-row { display:flex; gap:8px; }
.bk-coupon-row input { flex:1; }
.bk-coupon-msg { font-size:13px; margin-top:6px; min-height:16px; }
.bk-coupon-msg.is-ok { color:#15803d; font-weight:600; }
.bk-coupon-msg.is-error { color:#d63638; }
.bk-summary .bk-total { font-weight:700; color:#0b1b3a; }
