/* Hub Outils Voyage — grille cards outils + destinations */

.smc-hub-outils { background: linear-gradient(180deg, var(--cream-soft, #FBF5E6) 0%, transparent 100%); }

.smc-hub-tools {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
	margin: 24px 0;
}
.smc-hub-tool {
	background: #FFFFFF;
	border: 1px solid var(--line, #D9CFB8);
	border-radius: 16px;
	padding: 26px 24px;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	display: flex;
	flex-direction: column;
	text-decoration: none !important;
	color: #14223A !important;
}
.smc-hub-tool:hover {
	transform: translateY(-4px);
	border-color: rgba(184, 147, 92, .4);
	box-shadow: 0 14px 32px rgba(20, 34, 58, .1);
}
.smc-hub-tool__icon {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, #D4B27E 0%, #B8935C 100%);
	color: #14223A;
	font-size: 26px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
	box-shadow: 0 6px 18px rgba(184, 147, 92, .3);
}
.smc-hub-tool__title {
	font-family: 'Cormorant Garamond', serif;
	font-size: 22px;
	font-weight: 500;
	color: #14223A;
	margin: 0 0 8px;
	letter-spacing: -.2px;
}
.smc-hub-tool__pitch {
	font-size: 14.5px;
	line-height: 1.55;
	color: #2E4166;
	margin: 0 0 14px;
	flex: 1;
}
.smc-hub-tool__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: #B8935C !important;
	font-weight: 700;
	font-size: 13px;
	letter-spacing: .5px;
	text-transform: uppercase;
	margin-top: auto;
}
.smc-hub-tool:hover .smc-hub-tool__cta { gap: 10px; }

@media (min-width: 600px) {
	.smc-hub-tools { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 980px) {
	.smc-hub-tools { grid-template-columns: repeat(3, 1fr); }
}

/* Destinations grid */
.smc-hub-destinations {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin: 24px 0;
}
@media (min-width: 600px) { .smc-hub-destinations { grid-template-columns: repeat(4, 1fr); } }
.smc-hub-destination {
	background: #FFFFFF;
	border: 1px solid var(--line, #D9CFB8);
	border-radius: 12px;
	padding: 18px 14px;
	text-decoration: none !important;
	color: #14223A !important;
	text-align: center;
	transition: all .2s ease;
}
.smc-hub-destination:hover {
	border-color: #B8935C;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(184, 147, 92, .15);
}
.smc-hub-destination__flag { font-size: 26px; line-height: 1; display: block; margin-bottom: 6px; }
.smc-hub-destination__name { font-family: 'Poppins', sans-serif; font-size: 14px; font-weight: 600; }

/* Bloc préparer voyage final */
.smc-hub-prepare {
	background: linear-gradient(135deg, #14223A 0%, #2E4166 100%);
	color: #F7F1E3;
	padding: 36px 28px;
	border-radius: 22px;
	margin: 32px 0;
	position: relative;
	overflow: hidden;
}
.smc-hub-prepare::before {
	content: ""; position: absolute; top: -120px; right: -100px;
	width: 320px; height: 320px;
	background: radial-gradient(circle, rgba(212, 178, 126, .22) 0%, transparent 70%);
	pointer-events: none;
}
.smc-hub-prepare > * { position: relative; z-index: 1; }
.smc-hub-prepare__title {
	font-family: 'Cormorant Garamond', serif;
	font-size: 26px;
	color: #F7F1E3;
	text-align: center;
	margin: 0 0 8px;
}
.smc-hub-prepare__title em { color: #D4B27E; font-style: italic; }
.smc-hub-prepare__intro { text-align: center; color: rgba(247, 241, 227, .85); font-size: 14px; margin: 0 0 22px; }
.smc-hub-prepare__ctas {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
@media (min-width: 600px) { .smc-hub-prepare__ctas { grid-template-columns: repeat(3, 1fr); } }
.smc-hub-prepare__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 16px;
	background: rgba(247, 241, 227, .08);
	border: 1px solid rgba(212, 178, 126, .35);
	border-radius: 12px;
	color: #F7F1E3 !important;
	text-decoration: none !important;
	font-family: 'Poppins', sans-serif;
	font-size: 13px;
	font-weight: 600;
	transition: all .25s ease;
	backdrop-filter: blur(4px);
}
.smc-hub-prepare__cta:hover {
	background: rgba(247, 241, 227, .15);
	border-color: #D4B27E;
	transform: translateY(-2px);
}
