/**
 * ミライズレンタカー 予約フォーム CSS
 */

/* 予約ページ全体 */
.mirais-reserve-page {
	max-width: 900px;
	margin: 0 auto;
}

.mirais-reserve-stepper {
	display: flex;
	gap: 0;
	background: #fff;
	border: 1px solid var(--mirais-border);
	border-radius: 10px;
	padding: 16px;
	margin-bottom: 20px;
	overflow-x: auto;
}

.mirais-reserve-step {
	flex: 1;
	min-width: 100px;
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 0 10px;
	position: relative;
	color: var(--mirais-text-sub);
}

.mirais-reserve-step:not(:last-child)::after {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	width: 16px;
	height: 1px;
	background: var(--mirais-border);
}

.mirais-reserve-step .step-num {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #eee;
	color: var(--mirais-text-sub);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 600;
	flex-shrink: 0;
}

.mirais-reserve-step .step-label {
	font-size: 12px;
	font-weight: 500;
}

.mirais-reserve-step.active {
	color: var(--mirais-primary);
}

.mirais-reserve-step.active .step-num {
	background: var(--mirais-primary);
	color: #fff;
}

.mirais-reserve-step.done {
	color: var(--mirais-success);
}

.mirais-reserve-step.done .step-num {
	background: var(--mirais-success);
	color: #fff;
}

/* 予約フォーム コンテンツ */
.mirais-reserve-content {
	background: #fff;
	border: 1px solid var(--mirais-border);
	border-radius: 12px;
	padding: 28px;
}

.mirais-reserve-content h2 {
	font-size: 20px;
	margin: 0 0 18px;
}

/* 選択中の車両表示 */
.mirais-selected-vehicle {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 14px;
	background: var(--mirais-bg-alt);
	border-radius: 8px;
	margin-bottom: 20px;
}

.mirais-selected-vehicle .emoji {
	font-size: 40px;
	flex-shrink: 0;
}

.mirais-selected-vehicle .info {
	flex: 1;
	min-width: 0;
}

.mirais-selected-vehicle .name {
	font-size: 14px;
	font-weight: 600;
	margin: 0;
}

.mirais-selected-vehicle .spec {
	font-size: 11px;
	color: var(--mirais-text-sub);
}

.mirais-selected-vehicle .price {
	font-size: 20px;
	font-weight: 700;
	color: var(--mirais-primary);
	flex-shrink: 0;
	font-variant-numeric: tabular-nums;
}

/* フォームグリッド */
.mirais-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 16px;
}

.mirais-form-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.mirais-form-field.full {
	grid-column: 1 / -1;
}

.mirais-form-field label {
	font-size: 12px;
	color: var(--mirais-text-sub);
	font-weight: 500;
}

.mirais-form-field label .req {
	color: var(--mirais-danger);
}

.mirais-form-field .hint {
	font-size: 11px;
	color: var(--mirais-text-sub);
	font-weight: 400;
}

/* 予約モード選択カード */
.mirais-booking-mode-cards {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 20px;
}

.mirais-booking-mode-card {
	background: #fff;
	border: 2px solid var(--mirais-border);
	border-radius: 10px;
	padding: 18px;
	cursor: pointer;
	transition: all 0.2s;
	position: relative;
}

.mirais-booking-mode-card:hover {
	border-color: var(--mirais-primary);
	transform: translateY(-1px);
}

.mirais-booking-mode-card.active {
	border-color: var(--mirais-primary);
	background: var(--mirais-primary-light);
}

.mirais-booking-mode-card.active::before {
	content: '✓';
	position: absolute;
	top: 10px;
	right: 14px;
	width: 24px;
	height: 24px;
	background: var(--mirais-primary);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 700;
}

.mirais-booking-mode-card .icon {
	font-size: 28px;
	margin-bottom: 8px;
}

.mirais-booking-mode-card .title {
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 4px;
}

.mirais-booking-mode-card .desc {
	font-size: 11px;
	color: var(--mirais-text-sub);
	line-height: 1.6;
}

.mirais-booking-mode-card .recommended {
	display: inline-block;
	padding: 2px 8px;
	background: var(--mirais-accent);
	color: #fff;
	border-radius: 10px;
	font-size: 9px;
	font-weight: 600;
	margin-left: 6px;
	letter-spacing: 0.04em;
}

.mirais-booking-mode-card .benefits {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px dashed var(--mirais-border);
	list-style: none;
	padding-left: 0;
}

.mirais-booking-mode-card .benefits li {
	font-size: 11px;
	padding: 2px 0 2px 18px;
	position: relative;
	line-height: 1.6;
}

.mirais-booking-mode-card .benefits li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--mirais-success);
	font-weight: 700;
}

/* 会員登録時の追加フォーム */
.mirais-signup-extra {
	background: linear-gradient(135deg, #E8F5E9 0%, #F1F8F1 100%);
	border: 1px solid var(--mirais-success);
	border-radius: 8px;
	padding: 18px;
	margin: 16px 0;
}

.mirais-signup-extra .head {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
}

.mirais-signup-extra .head .icon {
	font-size: 22px;
}

.mirais-signup-extra .head h4 {
	font-size: 14px;
	color: #1B5E20;
	margin: 0;
}

.mirais-signup-extra .head p {
	font-size: 11px;
	color: #2E7D32;
	margin: 2px 0 0 0;
}

.mirais-signup-extra .agree-mini {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 11px;
	color: var(--mirais-text-sub);
	margin-top: 12px;
	cursor: pointer;
}

.mirais-signup-extra .agree-mini input {
	margin-top: 3px;
	flex-shrink: 0;
	width: auto;
}

/* 予約フォーム アクションボタン */
.mirais-reserve-actions {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid var(--mirais-bg-alt);
}

/* オプション一覧 */
.mirais-options-block {
	margin-bottom: 24px;
}

.mirais-options-block h4 {
	font-size: 13px;
	color: var(--mirais-text-sub);
	margin: 0 0 10px;
	padding-bottom: 6px;
	border-bottom: 1px solid var(--mirais-bg-alt);
}

.mirais-option-item {
	display: flex;
	gap: 12px;
	align-items: center;
	padding: 10px;
	border: 1px solid var(--mirais-border);
	border-radius: 6px;
	margin-bottom: 8px;
	cursor: pointer;
	transition: all 0.15s;
}

.mirais-option-item:hover {
	border-color: var(--mirais-primary);
	background: var(--mirais-primary-light);
}

.mirais-option-item input[type="checkbox"] {
	width: auto;
	margin: 0;
}

.mirais-option-item .info {
	flex: 1;
	min-width: 0;
}

.mirais-option-item .name {
	font-size: 13px;
	font-weight: 500;
	margin: 0 0 2px;
}

.mirais-option-item .desc {
	font-size: 11px;
	color: var(--mirais-text-sub);
}

.mirais-option-item .price {
	font-size: 13px;
	font-weight: 600;
	color: var(--mirais-primary);
	font-variant-numeric: tabular-nums;
	flex-shrink: 0;
}

/* 価格内訳 */
.mirais-price-breakdown {
	background: var(--mirais-bg-alt);
	border-radius: 8px;
	padding: 14px 16px;
	margin-bottom: 16px;
}

.mirais-price-breakdown .line {
	display: flex;
	justify-content: space-between;
	padding: 4px 0;
	font-size: 13px;
}

.mirais-price-breakdown .line.discount {
	color: var(--mirais-success);
}

.mirais-price-breakdown .line.total {
	font-size: 16px;
	font-weight: 700;
	padding-top: 10px;
	margin-top: 8px;
	border-top: 1px solid var(--mirais-border);
	color: var(--mirais-primary);
}

.mirais-price-breakdown .line .value {
	font-variant-numeric: tabular-nums;
}

/* クーポンコード入力 */
.mirais-coupon-input {
	display: flex;
	gap: 8px;
	margin-bottom: 14px;
}

.mirais-coupon-input input {
	flex: 1;
	font-family: monospace;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.mirais-coupon-input button {
	white-space: nowrap;
	flex-shrink: 0;
}

.mirais-coupon-applied {
	padding: 10px 14px;
	background: rgba(99, 153, 34, 0.1);
	border: 1px solid var(--mirais-success);
	border-radius: 6px;
	font-size: 12px;
	color: #2f4d12;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 14px;
}

.mirais-coupon-applied button {
	background: none;
	border: none;
	color: var(--mirais-text-sub);
	cursor: pointer;
	font-size: 11px;
}

/* 支払い方法選択 */
.mirais-payment-methods {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 8px;
	margin-bottom: 16px;
}

.mirais-payment-method {
	border: 2px solid var(--mirais-border);
	border-radius: 6px;
	padding: 12px;
	text-align: center;
	cursor: pointer;
	transition: all 0.15s;
	background: #fff;
}

.mirais-payment-method:hover {
	border-color: var(--mirais-primary);
}

.mirais-payment-method.active {
	border-color: var(--mirais-primary);
	background: var(--mirais-primary-light);
}

.mirais-payment-method .icon {
	font-size: 22px;
	margin-bottom: 4px;
}

.mirais-payment-method .name {
	font-size: 11px;
	font-weight: 500;
}

/* 完了画面 */
.mirais-complete {
	text-align: center;
	padding: 40px 20px;
}

.mirais-complete .icon {
	width: 80px;
	height: 80px;
	background: var(--mirais-success);
	color: #fff;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 40px;
	margin-bottom: 16px;
}

.mirais-complete h2 {
	font-size: 22px;
	margin: 10px 0;
}

.mirais-complete p {
	color: var(--mirais-text-sub);
	margin-bottom: 20px;
}

.mirais-reservation-no {
	display: inline-block;
	background: var(--mirais-bg-alt);
	border: 1px solid var(--mirais-border);
	border-radius: 8px;
	padding: 14px 24px;
	margin: 0 auto 20px;
}

.mirais-reservation-no .lbl {
	font-size: 11px;
	color: var(--mirais-text-sub);
}

.mirais-reservation-no .no {
	font-family: monospace;
	font-size: 22px;
	font-weight: 700;
	color: var(--mirais-primary);
}

/* スマホ対応 */
@media (max-width: 768px) {
	.mirais-reserve-content { padding: 16px; }
	.mirais-form-row { grid-template-columns: 1fr; gap: 14px; }
	.mirais-booking-mode-cards { grid-template-columns: 1fr; }
	.mirais-reserve-stepper { padding: 10px; }
	.mirais-reserve-step .step-label { display: none; }
	.mirais-reserve-step { min-width: 40px; }
	.mirais-selected-vehicle { flex-direction: column; text-align: center; }
}
