
/*@font-face {
	font-family: myFont;
	src: url(../fonts/iannnnn-DUCK-Regular.ttf);
}*/

@font-face {
	font-family: myFont;
	src: url(../fonts/NotoSansThai-VariableFont_wdth,wght.ttf);
}

html, body{
	height:100% !important;
	scroll-behavior: smooth;
}

body{
	font-family: myFont !important;
}

div{
	font-family: myFont !important;
}

h1, h2, h3, h4, h5, h6, ul, li, a, p, b, font, th, td, pre, tt, span{
	font-family: myFont !important;
}

label{
	font-family: myFont !important;
	font-weight: 600 !important;
}

body{
	padding-top: var(--nav-h);
}

p{
    font-size: 16px;
    line-height: unset;
    margin-bottom: 10px;
    word-break: break-word;
}

hr{
    border-top: 1px solid #d5d8dc !important;
}

pre {
	white-space: pre-wrap !important;
	word-break: normal !important;
	width: 100% !important;
	display: -webkit-inline-box !important;
	font-size: unset !important;
}

a {
    color: unset !important;
    text-decoration: none !important;
    display: block !important;
}

a:hover{
	text-decoration: none !important;
}

.swal2-img-maxheight {
	max-height: 90vh !important;
	width: auto !important;
	height: auto !important;
	border-radius: 18px;
	display: block;
	margin: 0 auto;
}

.minh-500{
	min-height: 500px;
}

.bdrd-15{
	border-radius: 15px;
}

.my-dashed{
	border-top: 1px dashed #E0E0E0;
	width: 100% !important;
	margin: 10px 0px;
}

.form-label{
	font-size: 14px !important;
}

/* -------------------------------------------- */

.text-1-lines{
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 1; /* number of lines to show */
	-webkit-box-orient: vertical;
}

.text-2-lines{
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2; /* number of lines to show */
	-webkit-box-orient: vertical;
}

.text-3-lines{
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 3; /* number of lines to show */
	-webkit-box-orient: vertical;
}

.font-main{
	color: #9B0000 !important;
}

.my-font-10{
	font-size: 10px !important;
}

.my-font-12{
	font-size: 12px !important;
}

.my-font-14{
	font-size: 14px !important;
}

.my-font-16{
	font-size: 16px !important;
}

.my-font-18{
	font-size: 18px !important;
}

.my-font-20{
	font-size: 20px !important;
}

.my-font-22{
	font-size: 22px !important;
}

.my-font-24{
	font-size: 24px !important;
}

.my-font-26{
	font-size: 26px !important;
}

.my-font-28{
	font-size: 28px !important;
}

.my-font-30{
	font-size: 30px !important;
}

.text-pink{
	color: #d63384;
}

/* -------------------------------------------- */

:root{
	--rn-primary:#27A6F5;
	--rn-primary-soft:rgba(39,166,245,.12);
	--rn-primary-soft-strong:rgba(39,166,245,.22);
	--rn-bg:#f8fbff;
	--rn-shell-radius:32px;
	--rn-shadow-soft:0 24px 70px rgba(15,23,42,.18);
	--rn-shadow-card:0 16px 40px rgba(15,23,42,.12);
	--rn-nav-h:67px;
}

/* ===== BODY ===== */
.rn-body{
	margin:0;
	background:var(--rn-bg);
	font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
	color:#111827;
}

/* ===== NAVBAR ===== */
.rn-navbar{
	background:#ffffff;
	box-shadow:0 14px 40px rgba(15,23,42,.16);
	padding:10px 18px;
}

.rn-navbar-inner{
	max-width:1180px;
	margin:0 auto;
}

.rn-header{
	padding-top:var(--rn-nav-h);
}

/* logo / brand */
.rn-logo-circle{
	width:34px;
	height:34px;
	border-radius:50%;
	background:#111827;
	color:#facc15;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	font-weight:800;
	font-size:16px;
}

.rn-brand-text{
	display:flex;
	flex-direction:column;
	margin-left:8px;
}

.rn-brand-main{
	font-weight:700;
	font-size:18px;
	line-height:1.1;
}

.rn-brand-sub{
	font-size:11px;
	color:#6b7280;
}

/* main nav links */
.rn-nav-link{
	position:relative;
	border-radius:999px;
	padding:.5rem .95rem;
	margin:0 .15rem;
	font-size:14px;
	font-weight:500;
	color:#4b5563;
	transition:
		color .18s ease,
		background .18s ease,
		transform .18s ease,
		box-shadow .18s ease;
}

.rn-nav-link:hover{
	color:#111827;
	background:var(--rn-primary-soft);
	transform:translateY(-1px);
	box-shadow:0 10px 28px rgba(39,166,245,.26);
}

.rn-nav-link.active{
	color:#111827;
	/*background:var(--rn-primary-soft-strong);
	box-shadow:0 10px 28px rgba(39,166,245,.3);*/
}

.rn-nav-link.active::after{
	content:"";
	position:absolute;
	left:10px;
	right:10px;
	bottom:5px;
	height:3px;
	border-radius:999px;
	background:linear-gradient(90deg,#22c1ff,#27A6F5,#1a78d7);
}

/* ปุ่มจองบน navbar – ขาวขอบฟ้านุ่ม ๆ */
.rn-btn-primary{
	border-radius:999px;
	border:1px solid rgba(39,166,245,.45);
	background:#ffffff;
	color:#1f2933;
	font-size:14px;
	font-weight:500;
	padding:8px 18px;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	box-shadow:0 8px 22px rgba(15,23,42,.08);
	transition:
		background .18s ease,
		color .18s ease,
		transform .18s ease,
		box-shadow .18s ease;
}

.rn-btn-primary:hover{
	background:linear-gradient(135deg,#27A6F5,#62c7ff);
	color:#ffffff;
	transform:translateY(-1px);
	box-shadow:0 16px 36px rgba(39,166,245,.45);
}

/* navbar toggler – ไม่ดำ ทรงมินิมอล */
.rn-navbar-toggler{
	border:1px solid rgba(148,163,184,.6);
	outline:none;
	box-shadow:none !important;
	width:40px;
	height:40px;
	border-radius:999px;
	background:#ffffff;
	display:flex;
	align-items:center;
	justify-content:center;
}

.rn-navbar-toggler-icon{
	width:19px;
	height:2px;
	border-radius:999px;
	background:#334155;
	position:relative;
}

.rn-navbar-toggler-icon::before,
.rn-navbar-toggler-icon::after{
	content:"";
	position:absolute;
	left:0;
	width:100%;
	height:2px;
	border-radius:999px;
	background:#334155;
	transition:transform .18s ease, top .18s ease, bottom .18s ease;
}

.rn-navbar-toggler-icon::before{
	top:-6px;
}
.rn-navbar-toggler-icon::after{
	bottom:-6px;
}

.rn-navbar-toggler[aria-expanded="true"] .rn-navbar-toggler-icon{
	background:transparent;
}

.rn-navbar-toggler[aria-expanded="true"] .rn-navbar-toggler-icon::before{
	top:0;
	transform:rotate(45deg);
}

.rn-navbar-toggler[aria-expanded="true"] .rn-navbar-toggler-icon::after{
	bottom:0;
	transform:rotate(-45deg);
}

/* ===== OFFCANVAS เมนูมือถือ ===== */
.rn-offcanvas-menu{
	background:#ffffff;
	border-top-right-radius:24px;
	border-bottom-right-radius:24px;
	box-shadow:0 24px 60px rgba(15,23,42,.25);
}

/* ===== HERO ===== */
.rn-hero{
	position:relative;
	width:100%;
	max-width:100%;                        /* เดิม max-width:1180px; */
	margin:0;                              /* เดิม margin:0 auto;    */
	border-radius:0 0 var(--rn-shell-radius) var(--rn-shell-radius);
	overflow:visible;                      /* ให้การ์ดค้นหายื่นลงมาได้ */
	box-shadow:none;                       /* ตัดเงากรอบใหญ่ออก เหลือแต่เงาการ์ดค้นหา */
}

.rn-hero-bg{
	position:relative;
	height:380px;
	width:100%;                            /* ให้ชัวร์ว่าเต็มความกว้าง hero */
}

.rn-hero-bg img{
	width:100%;
	height:100%;
	object-fit:cover;
	border-radius:0 0 var(--rn-shell-radius) var(--rn-shell-radius);
}

.rn-hero-overlay{
	position:absolute;
	inset:0;
	background:linear-gradient(
		to bottom,
		rgba(0,0,0,.28),
		rgba(0,0,0,.06) 40%,
		rgba(248,251,255,1) 100%
	);
	border-radius:0 0 var(--rn-shell-radius) var(--rn-shell-radius);
}

.rn-hero-content{
	position:absolute;
	inset:0;
	display:flex;
	flex-direction:column;
	justify-content:center;
	align-items:flex-start;
	color:#ffffff;
	z-index:2;
}

.rn-hero-content h1{
	font-size:34px;
	font-weight:700;
	margin-bottom:6px;
	text-shadow:0 0 20px rgba(0,0,0,.4);
}

.rn-hero-content p{
	max-width:460px;
	font-size:15px;
	margin-bottom:18px;
	text-shadow:0 0 12px rgba(0,0,0,.45);
}

.rn-hero-actions{
	display:flex;
	flex-wrap:wrap;
	gap:10px;
}

/* ปุ่มใน hero */
.rn-btn-hero-primary{
	border-radius:999px;
	border:none;
	background:linear-gradient(135deg,#27A6F5,#62c7ff);
	color:#ffffff;
	font-size:14px;
	font-weight:500;
	padding:9px 22px;
	display:inline-flex;
	align-items:center;
	box-shadow:0 16px 36px rgba(0,0,0,.35);
	transition:
		transform .18s ease,
		box-shadow .18s ease,
		filter .18s ease;
}

.rn-btn-hero-primary:hover{
	transform:translateY(-1px);
	box-shadow:0 22px 46px rgba(0,0,0,.4);
	filter:brightness(1.03);
}

.rn-btn-hero-ghost{
	border-radius:999px;
	border:1px solid rgba(255,255,255,.8);
	background:rgba(255,255,255,.12);
	color:#ffffff;
	font-size:14px;
	padding:8px 20px;
	display:inline-flex;
	align-items:center;
	transition:
		background .18s ease,
		color .18s ease,
		transform .18s ease;
}

.rn-btn-hero-ghost:hover{
	background:rgba(255,255,255,.22);
	transform:translateY(-1px);
}

/* ===== SEARCH CARD ใต้ HERO (แทน toolbar เดิม) ===== */
.search-card-wrapper{
	position:absolute;
	left:0;
	right:0;
	bottom:-38px;      /* ปรับ -32 / -40 ได้ตามที่ชอบ */
	z-index:3;
	margin:0;
}

.search-card{
	background:#ffffff;
	border-radius:20px;
	box-shadow:0 18px 45px rgba(15,23,42,.14);
	padding:14px 18px;
}

.search-label{
	font-size:14px;
	font-weight:600;
	color:#111827;
}

.my-font-18{
	font-size:16px;
}

/* select ในการ์ดค้นหา */
.search-card .form-select{
	border-radius:999px;
	border:1px solid rgba(148,163,184,.8);
	font-size:14px;
	padding:.45rem .9rem;
	background-color:#f9fafb;
	transition:
		border-color .18s ease,
		box-shadow .18s ease,
		background .18s ease;
}

.search-card .form-select:focus{
	border-color:#27A6F5;
	box-shadow:0 0 0 3px rgba(39,166,245,.16);
	background-color:#ffffff;
}

/* ===== ปุ่มค้นหา – Minimal Modern ===== */
.btn-search{
	border-radius:999px;
	border:none;
	background:#27A6F5;	/* สีหลัก flat */
	color:#ffffff;
	font-size:14px;
	font-weight:500;
	padding:10px 20px;
	display:inline-flex;
	align-items:center;
	justify-content:center;

	/* เงาบางมาก ไม่ทะลุ ไม่เรือง */
	box-shadow:0 4px 12px rgba(39,166,245,.18);

	transition:
		background .2s ease,
		box-shadow .2s ease;
}

.btn-search i{
	font-size:14px;
	margin-right:6px;
}

/* hover แค่เข้มขึ้นนิดเดียว ไม่ลอย */
.btn-search:hover{
	background:#1f8fe0;
	box-shadow:0 6px 16px rgba(39,166,245,.22);
}

/* กด */
.btn-search:active{
	background:#197ed0;
	box-shadow:0 2px 6px rgba(39,166,245,.18);
}

/* ===== MAIN SECTION ===== */
.rn-main{
	background:#f9fbff;
	padding:70px 0 60px;	/* เดิม 40px 0 60px เพิ่มบนขึ้นหน่อย */
}

.rn-section{
	/*max-width:1180px;*/
	margin:0 auto;
}

.rn-section-top{
	margin-top:4px;
}

.rn-section-title{
	font-size:22px;
	font-weight:700;
	margin-bottom:18px;
}

/* การ์ดแพ็กเกจ */
.rn-package-card{
	border-radius:22px;
	background:#ffffff;
	overflow:hidden;
	box-shadow:var(--rn-shadow-card);
	display:flex;
	flex-direction:column;
	height:100%;
	transition:
		transform .18s ease,
		box-shadow .18s ease;
}

.rn-package-card:hover{
	transform:translateY(-4px);
	box-shadow:0 24px 60px rgba(15,23,42,.2);
}

.rn-pc-img-wrap{
	height:240px;
	overflow:hidden;
}

.rn-pc-img-wrap img{
	width:100%;
	height:100%;
	object-fit:cover;
}

.rn-pc-body{
	padding:14px 16px 14px;
	display:flex;
	flex-direction:column;
	flex:1;
}

.rn-pc-title{
	font-size:16px;
	font-weight:600;
	margin-bottom:2px;
}

.rn-pc-desc{
	font-size:13px;
	color:#6b7280;
	margin-bottom:10px;
}

.rn-pc-meta{
	display:flex;
	align-items:flex-end;
	justify-content:space-between;
	gap:10px;
	margin-top:auto;
}

.rn-pc-rating{
	font-size:13px;
	color:#4b5563;
	display:flex;
	flex-direction:column;
}

.rn-stars{
	color:#f97316;
	font-size:14px;
}

.rn-pc-rating-count{
	font-size:11px;
	color:#9ca3af;
}

.rn-pc-price{
	text-align:right;
}

.rn-pc-price-main{
	display:block;
	font-weight:700;
	font-size:16px;
	color:#111827;
}

.rn-pc-price-sub{
	display:block;
	font-size:11px;
	color:#6b7280;
}

@media (max-width: 991.98px){
	.rn-header{
		padding-top:64px;
	}

	.rn-hero-bg{
		height:520px;
	}

	.rn-hero-content{
		/*justify-content:flex-start;*/
		padding:70px 1.5rem 260px;
	}

	.rn-hero-content h1{
		font-size:24px;
		margin-bottom:6px;
	}

	.rn-hero-content p{
		max-width:100%;
		font-size:14px;
	}

	.search-card-wrapper{
		bottom:-10px;
	}

	.search-card{
		border-radius:18px;
		padding:12px 14px 16px;
	}

	.rn-main{
		padding-top:60px;
	}
}

@media (max-width: 575.98px){
	.rn-hero-bg{
		height:540px;
	}

	.rn-hero-content{
		padding:60px 1.25rem 280px;
	}

	.rn-hero-content h1{
		font-size:22px;
	}

	.search-card{
		padding:12px 12px 14px;
	}
}

/* -------------------------------------------- */

/* การ์ดทั้งใบ – ให้ลอยนิด ๆ */
.rn-package-card{
	border-radius: 26px;
	background: #ffffff;
	box-shadow: 0 16px 32px rgba(22,40,80,.08);
	transition: transform .26s ease, box-shadow .26s ease;
}

/* hover ให้เด้งขึ้นนิดเดียว แบบเนียน ๆ */
.rn-package-card:hover{
	transform: translateY(-6px);
	box-shadow: 0 24px 46px rgba(22,40,80,.14);
}

/* ห่อรูป – ทำให้มีเงาใต้รูปแบบนวล ๆ */
.rn-pc-img-wrap{
	position: relative;
	border-radius: 26px 26px 0 0;
	overflow: hidden;
}

/* รูปเอง – ทำให้ครอบเต็มสวย ๆ และมี motion ตอน hover */
.rn-pc-img-wrap img{
	display: block;
	width: 100%;
	object-fit: cover;
	transition: transform .45s ease;
}

/* hover แล้วซูมเบา ๆ พอให้รู้สึกมีชีวิต */
.rn-package-card:hover .rn-pc-img-wrap img{
	transform: scale(1.03);
}

/* เนื้อการ์ดด้านล่าง */
.rn-pc-body{
	padding: 18px 22px 20px;
}

/* ⭐ โซนดาว + รีวิว ให้ดูพรีเมียมขึ้น */
.rn-pc-rating{
	display: flex;
	gap: 10px;
	margin-bottom: 6px;
}

/* ดาว – สีส้มทองนุ่ม ๆ + ระยะห่าง */
.rn-stars{
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 14px;
	color: #FFB321;
}

.rn-stars i{
	transition: transform .2s ease, color .2s ease;
}

/* hover แล้วดาวขยับนิดเดียว */
.rn-package-card:hover .rn-stars i{
	transform: translateY(-1px);
}

/* คะแนนตัวเลข */
.rn-score{
	font-weight: 600;
	font-size: 15px;   /* เพิ่มจาก 14 เป็น 15 */
	color: #1E293B;
	letter-spacing: .2px;
}

/* จำนวนรีวิว – ให้ดูซอฟต์ลง */
.rn-pc-rating-count{
	margin-left: 6px;
	font-size: 13px;
	color: #9FA4B4;
}

/* ราคา – เน้นตัวเลขให้เด่น แต่ไม่แทงตาเกินไป */
.rn-pc-price-main{
	font-weight: 700;
	font-size: 18px;
	color: #0E1726;
}

.rn-pc-price-sub{
	display: block;
	font-size: 13px;
	color: #9FA4B4;
}

/* -------------------------------------------- */

.rn-review-card{
	border-radius: 18px;
	background: #ffffff;
	padding: 16px 18px;
	box-shadow: 0 10px 24px rgba(15,23,42,.06);
	height: auto;
	display: block;

	transition: 
		transform .28s cubic-bezier(.22,.61,.36,1),
		box-shadow .28s cubic-bezier(.22,.61,.36,1);
	will-change: transform;
}

/* hover แบบนุ่ม ๆ */
.rn-review-card:hover{
	transform: translateY(-6px);
	box-shadow: 0 18px 36px rgba(15,23,42,.12);
}

.rn-review-room{
	font-weight: 600;
	font-size: 15px;
	color: #111827;
}

.rn-review-stars{
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	color: #FFB321;
}

.rn-review-stars i{
	margin-right: 1px;
}

.rn-review-score{
	font-size: 13px;
	font-weight: 600;
	color: #1E293B;
	margin-left: 4px;
}

.rn-review-detail{
	font-size: 14px;
	color: #4B5563;
	line-height: 1.5;
	margin-top: 4px;
}

.rn-review-meta{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 8px;
	font-size: 12px;
	color: #9CA3AF;
}

/* -------------------------------------------- */

/* ปุ่ม Go To Top */
.rn-go-top{
	position: fixed;
	right: 28px;
	bottom: 28px;

	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: none;

	background: #ffffff;
	color: #1E293B;
	font-size: 16px;

	box-shadow: 0 10px 25px rgba(15,23,42,.12);

	display: flex;
	align-items: center;
	justify-content: center;

	cursor: pointer;

	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);

	transition: 
		opacity .25s ease,
		transform .25s ease,
		box-shadow .25s ease;
	z-index: 999;
}

/* แสดงปุ่ม */
.rn-go-top.show{
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* hover */
.rn-go-top:hover{
	box-shadow: 0 18px 35px rgba(15,23,42,.18);
	transform: translateY(-3px);
}

/* -------------------------------------------- */

/* ===== Calendar Card ===== */
.rn-cal-card{
	background:#ffffff;
	border-radius:24px;
	padding:24px 24px 20px;
	box-shadow:0 18px 40px rgba(15,76,129,.06);
	border:1px solid rgba(15,76,129,.04);
}

/* Header: title / month / today */
.rn-cal-header{
	display:flex;
	align-items:flex-start;
	justify-content:space-between;
	gap:16px;
	margin-bottom:8px;
}

.rn-cal-title{
	font-size:1.4rem;
	font-weight:700;
	color:#0f3654;
}

.rn-cal-sub{
	font-size:.95rem;
	color:#7a8795;
	margin-top:2px;
}

.rn-cal-today{
	font-size:.9rem;
	color:#27A6F5;
	font-weight:500;
}

/* Legend */
.rn-cal-legend{
	display:flex;
	align-items:center;
	gap:14px;
	margin-top:10px;
	margin-bottom:6px;
	font-size:.85rem;
	color:#6f7d8d;
}

.rn-cal-pill{
	display:inline-flex;
	align-items:center;
	gap:6px;
	padding:2px 10px;
	border-radius:999px;
	background:transparent;
}

.rn-cal-pill .dot{
	width:9px;
	height:9px;
	border-radius:50%;
	display:inline-block;
}

.rn-cal-pill-free .dot{
	background:#2fb8a3;
}

.rn-cal-pill-busy .dot{
	background:#e44c4c;
}

/* Grid */
.rn-cal-grid{
	margin-top:8px;
	display:grid;
	grid-template-columns:repeat(7,minmax(0,1fr));
	gap:10px;
	font-size:.9rem;
}

/* Weekday row */
.rn-cal-weekday{
	text-align:center;
	font-weight:600;
	color:#8a96a5;
	padding-bottom:6px;
	border-bottom:1px solid rgba(180,191,203,.55);
	text-transform:none;
}

/* Day cell base */
.rn-cal-day{
	padding:10px 10px;
	border-radius:18px;
	background:#f8fafc;
	border:1px solid transparent;
	display:flex;
	flex-direction:column;
	align-items:flex-start;
	justify-content:space-between;
	min-height:72px;
	transition:
		background .18s ease,
		box-shadow .18s ease,
		border-color .18s ease,
		transform .18s ease;
}

.rn-cal-day .day-num{
	font-weight:600;
	margin-bottom:6px;
}

.rn-cal-day .day-status{
	font-size:.8rem;
}

/* Free day */
.rn-cal-day.is-free{
	background:#f0fbf9;
	border-color:rgba(47,184,163,.35);
	color:#156b63;
}

.rn-cal-day.is-free .day-status{
	color:#1c8f83;
}

/* Busy day */
.rn-cal-day.is-busy{
	background:#fff4f4;
	border-color:rgba(226,77,77,.35);
	color:#b03b3b;
}

.rn-cal-day.is-busy .day-status{
	color:#d14b4b;
}

/* Today highlight (วงกรอบเบา ๆ) */
.rn-cal-day.is-today{
	background:#ffffff;
	border-width:2px;
	border-color:#27A6F5;
	box-shadow:0 0 0 1px rgba(39,166,245,.08);
}

/* Hover effect (ทั้ง free / busy) */
.rn-cal-day:not(.rn-cal-day-empty):hover{
	transform:translateY(-2px);
	box-shadow:0 10px 24px rgba(15,76,129,.10);
}

/* Empty cell */
.rn-cal-day-empty{
	background:transparent;
	border:none;
}

/* Responsive */
@media (max-width:991.98px){
	.rn-cal-card{
		padding:18px 16px 16px;
		border-radius:20px;
	}
	.rn-cal-grid{
		gap:6px;
	}
	.rn-cal-day{
		min-height:64px;
		padding:8px 8px;
	}
	.rn-cal-title{
		font-size:1.2rem;
	}
}

@media (max-width:575.98px){
	.rn-cal-header{
		flex-direction:column;
		align-items:flex-start;
		gap:6px;
	}
	.rn-cal-grid{
		font-size:.85rem;
	}
}

/* -------------------------------------------- */

/* การ์ดจองเรือนน้ำ */
.booking-panel{
	background: #ffffff;
	border-radius: 20px;
	padding: 24px 24px 20px;
	box-shadow: 0 12px 30px rgba(0,0,0,.04);
	border: 1px solid rgba(0,0,0,.04);
	display: flex;
	flex-direction: column;
	gap: 18px;
}

/* หัวฟอร์ม */
.booking-header{
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-bottom: 4px;
}

.booking-title{
	font-size: 1.25rem; /* ~20px */
	font-weight: 600;
	color: #222;
}

.booking-subtitle{
	font-size: .875rem;
	color: #6c757d;
}

/* ตัวฟอร์ม */
.booking-body{
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.booking-field{
	margin-bottom: 0; /* เราคุม spacing ด้วย gap แทน */
}

.booking-label{
	font-weight: 500;
	color: #333;
	font-size: .95rem;
	margin-bottom: 6px;
}

/* ช่องกรอก */
.booking-control{
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,.1);
	min-height: 44px;
	font-size: .95rem;
}

.booking-control:focus{
	border-color: #27A6F5;
	box-shadow: 0 0 0 2px rgba(39,166,245,.18);
}

/* กลุ่ม radio */
.booking-radio-group{
	display: flex;
	flex-wrap: wrap;
	gap: 10px 18px;
}

.booking-radio-group .form-check{
	margin-bottom: 0;
}

.booking-radio-group .form-check-input{
	width: 18px;
	height: 18px;
	margin-top: 1px;
}

.booking-radio-group .form-check-label{
	margin-left: 4px;
	font-size: .95rem;
}

/* ฟิลด์อ้างอิง จนท. */
.booking-ref{
	padding: 10px 12px;
	border-radius: 14px;
	background: rgba(39,166,245,.03);
	border: 1px dashed rgba(39,166,245,.25);
}

/* footer + ปุ่ม */
.booking-footer{
	margin-top: 8px;
	padding-top: 12px;
	border-top: 1px dashed rgba(0,0,0,.06);
}

.btn-booking{
	background: #27A6F5;
	border-radius: 999px;
	border: none;
	padding: 10px 16px;
	font-weight: 600;
	font-size: .95rem;
	color: #fff;
}

.btn-booking:hover,
.btn-booking:focus{
	background: #1f8fd5;
	color: #fff;
}

/* จอเล็ก ขยับ padding นิดหน่อย */
@media (max-width: 575.98px){
	.booking-panel{
		padding: 18px 16px 16px;
		border-radius: 16px;
	}
}

/* -------------------------------------------- */

.rn-gallery-link{
	display: block;
	text-decoration: none;
	color: inherit;
}

.rn-gallery-grid{
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.rn-gallery-item{
	border-radius: 14px;
	overflow: hidden;
	background: #f5f5f5;
	box-shadow: 0 4px 10px rgba(0,0,0,.06);
	transition: transform .18s ease, box-shadow .18s ease;
}

.rn-gallery-img{
	display: block;
	width: 100%;
	height: 90px;
	object-fit: cover;
}

.rn-gallery-item:hover{
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0,0,0,.09);
}

.rn-gallery-more{
	background: #E0E0E0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.rn-gallery-more-inner{
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: 500;
	color: #555;
}

.rn-gallery-more-inner i{
	opacity: .85;
}

/* -------------------------------------------- */

.rn-info-section{
	border-radius: 18px;
	background: #F7F8FA;
	padding: 18px 20px;
	margin-bottom: 14px;
}

.rn-info-title{
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 10px;
}

.rn-info-grid{
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px 20px;
}

.rn-info-item{
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	color: #333;
}

.rn-info-item i{
	color: #2E7D32;
	font-size: 14px;
}
@media (max-width: 768px){
	.rn-info-grid{
		grid-template-columns: 1fr;
	}
}

/* -------------------------------------------- */

.rn-price-highlight{
	color: #1c7ed6;
	font-size: 1.5rem;
	font-weight: 800;
}

/* -------------------------------------------- */

/* กล่องรูปตัวอย่างในแกลเลอรี่ */
.rn-gallery-thumb-wrap{
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3; /* ทำให้ทุกช่องเป็นสัดส่วนเท่ากัน */
	overflow: hidden;
	border-radius: 18px;
	background: #f4f7fb;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* รูปตัวอย่าง (thumbnail) */
.rn-gallery-thumb{
	width: 100%;
	height: 100%;
	object-fit: cover;
	cursor: pointer;
	transition:
		transform .18s ease,
		box-shadow .18s ease,
		opacity .18s ease;
}

.rn-gallery-thumb:hover{
	transform: scale(1.03);
	box-shadow: 0 10px 26px rgba(0,0,0,.18);
	opacity: .96;
}

/* กล่องใน SweetAlert */
.rn-gallery-modal{
	display: flex;
	align-items: center;
	justify-content: center;
}

/* รูปใหญ่ใน SweetAlert – ไม่ให้ทะลุจอ */
.rn-gallery-full{
	max-width: 90vw;
	max-height: 80vh;
	width: auto;
	height: auto;
	display: block;
	border-radius: 20px;
	box-shadow: 0 16px 40px rgba(0,0,0,.45);
}

/* -------------------------------------------- */

.rn-star{
	font-size: 24px;
	color: #cfd5e2;
	cursor: pointer;
	transition:
		transform .15s ease,
		color .15s ease,
		text-shadow .15s ease;
}

.rn-star.is-active{
	color: #ffc107;
	text-shadow: 0 4px 10px rgba(255,193,7,.5);
	transform: translateY(-1px);
}

.rn-star:hover{
	transform: translateY(-2px) scale(1.05);
}

/* -------------------------------------------- */

.rn-contact-card{
	background:#ffffff;
	border-radius:22px;
	padding:28px;
	box-shadow:0 10px 30px rgba(0,0,0,.06);
}

.rn-contact-item{
	display:flex;
	align-items:flex-start;
	gap:16px;
	margin-bottom:22px;
}

.rn-contact-item:last-child{
	margin-bottom:0;
}

.rn-contact-icon{
	width:42px;
	height:42px;
	min-width:42px;
	border-radius:12px;
	background:#f2f7fc;
	display:flex;
	align-items:center;
	justify-content:center;
	color:#27A6F5;
	font-size:18px;
}

.rn-contact-title{
	font-size:18px;
	font-weight:600;
	color:#1f2d3d;
	margin-bottom:6px;
}

.rn-contact-detail{
	font-size:14px;
	color:#6b7c93;
	line-height:1.7;
}

.rn-contact-link a{
	font-size:16px;
	font-weight:600;
	color:#27A6F5;
	text-decoration:none;
	transition:opacity .15s ease;
}

.rn-contact-link a:hover{
	opacity:.75;
}

.rn-contact-sub{
	font-size:13px;
	color:#8a9bb3;
	margin-top:4px;
}

/* -------------------------------------------- */