:root {
  --bg: #eef5f9;
  --surface: #ffffff;
  --surface-soft: #f6fbff;
  --brand: #0f3f58;
  --brand-strong: #082f42;
  --accent: #2f819f;
  --text: #1b2a33;
  --muted: #58707d;
  --line: #d6e6ef;
  --shadow: 0 12px 28px rgba(8, 47, 66, 0.1);
  --radius-lg: 18px;
  --radius-md: 12px;
  --max-width: 1120px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: 'Poppins', sans-serif;
  color: var(--text);
  background: linear-gradient(180deg,#f8fcff 0%,#eef5f9 100%);
  line-height: 1.6;
}

.page-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.site-header {

position:sticky;

top:0;

z-index:25;

background:rgba(15,63,88,0.75);

backdrop-filter:blur(12px);

-webkit-backdrop-filter:blur(12px);

border-bottom:1px solid rgba(255,255,255,0.2);

box-shadow:0 8px 20px rgba(0,0,0,0.08);

}

.header-wrap {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 14px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.brand{

color:#fff;

text-decoration:none;

font-weight:700;

letter-spacing:0.05em;

font-size:18px;

}

.site-nav a {
  color: #ebf7ff;
  text-decoration: none;
  margin-left: 12px;
  font-weight: 600;
}

.site-nav a.active {
  text-decoration: underline;
}

.hero {
  background:
    linear-gradient(rgba(7,30,42,0.6),rgba(7,30,42,0.5)),
    url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e') center/cover no-repeat;
  padding: 80px 20px;
  color: white;
  text-align: center;
}

.hero-card {
  max-width: 800px;
  margin: auto;
}

main {
  max-width: var(--max-width);
  margin: auto;
  padding: 30px 20px;
  flex: 1;
}

.section {
  background: white;
  padding: 28px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  margin-bottom: 24px;
}

.section-head h2 {
  margin-top: 0;
}

.grid-2 {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
}

.grid-3 {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit,minmax(200px,1fr));
}

.card {
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 16px;
}

.list,
.numbered {
  padding-left: 20px;
}

.package-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit,minmax(250px,1fr));
}

.package-card {
  background: #f9fcff;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 16px;
}

.price-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}

.price-chip {
  background: #eaf4fa;
  padding: 8px;
  border-radius: 8px;
  text-align: center;
}

.package-card.featured {
  background: linear-gradient(150deg,#0f3f58,#1a6e90);
  color: white;
}

.btn {
  display: inline-block;
  padding: 10px 18px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
}

.btn-primary {
  background: white;
  color: var(--brand);
}

.btn-brand {
  background: var(--brand);
  color: white;
}

.btn-facebook {
  background: #1877f2;
  color: white;
}

.footer {
  background: var(--brand);
  color: white;
  text-align: center;
  padding: 20px;
}

.floating-book {
  position: fixed;
  right: 16px;
  bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  border: 1px solid var(--line);
  padding: 10px;
}

th {
  background: #e8f2f8;
}

/* ===== HERO GLASS CARD ===== */

.hero-card{
max-width:820px;
margin:0 auto;
padding:34px;
border-radius:18px;

background:rgba(6,28,39,0.52);
backdrop-filter:blur(6px);

box-shadow:0 12px 28px rgba(8,47,66,0.2);
}


/* ===== HERO GRADIENT BACKGROUND ===== */

.hero{

background:
linear-gradient(rgba(7,30,42,0.63),rgba(7,30,42,0.42)),
url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e')
center/cover no-repeat;

padding:82px 20px;
color:#fff;

}


/* ===== SMALL SECTION LABEL ===== */

.kicker{

display:inline-block;

font-size:12px;
letter-spacing:0.06em;

text-transform:uppercase;

color:#2f819f;

background:#f6fbff;

border:1px solid #d6e6ef;

border-radius:999px;

padding:5px 12px;

font-weight:700;

margin-bottom:10px;

}


/* ===== NAVIGATION ACTIVE BUTTON ===== */

.site-nav a {
color:#ebf7ff;
text-decoration:none;
font-weight:600;
padding:10px 16px;
border-radius:999px;
border:1px solid transparent;
transition:all 0.2s ease;
font-size:14px;
}

.site-nav a:hover,
.site-nav a.active{

background:rgba(255,255,255,0.18);

border-color:rgba(255,255,255,0.28);

transform:translateY(-1px);

}


/* FEATURED PACKAGE CARD */

.package-card.featured{

background:linear-gradient(150deg,#0f3f58 0%,#1a6e90 100%);

border-color:#0f3f58;

color:#ffffff;

box-shadow: 0 18px 40px rgba(8,47,66,0.25)
}

.package-card.featured h3{
color:#ffffff;
}

.package-card.featured li{
color:#e9f4fb;
}

.package-card.featured strong{
color:#ffffff;
}

.package-card.featured .price-chip{

background:rgba(255,255,255,0.15);

border:1px solid rgba(255,255,255,0.35);

color:#ffffff;

}

.package-card.featured .price-chip small{

color:#cfe8f7;

}


/* ===== POLICY CARDS ===== */

.policy-list{

display:grid;
gap:12px;

}

.policy-item{

background:#f6fbff;

border:1px solid #d6e6ef;

border-radius:12px;

padding:16px;

}

/* ===== PACKAGE PRICE LAYOUT FIX ===== */

.price-row{

display:grid;
grid-template-columns:1fr 1fr;
gap:12px;
margin:12px 0 14px;

}

.price-chip{

border:1px solid #c7dbe7;

border-radius:12px;

background:#eaf4fa;

padding:12px;

text-align:center;

font-weight:600;

}

.price-chip small{

display:block;

text-transform:uppercase;

letter-spacing:0.05em;

color:#58707d;

font-size:11px;

margin-bottom:4px;

}

/* ===== PACKAGE CARD IMPROVEMENT ===== */

.package-card{

background:#f9fcff;

border:1px solid #d6e6ef;

border-radius:16px;

padding:18px;

transition:transform .15s ease, box-shadow .15s ease;

}

.package-card:hover{

transform:translateY(-3px);

box-shadow:0 14px 30px rgba(8,47,66,0.12);

}

.section-head h2{

font-size:28px;

margin-bottom:6px;

color:#082f42;

}

.section-head .lead{

color:#58707d;

max-width:700px;

}

.btn{

display:inline-block;

border-radius:999px;

padding:12px 20px;

font-weight:600;

border:1px solid transparent;

transition:all .2s ease;

}

.btn:hover{

transform:translateY(-1px);

box-shadow:0 6px 14px rgba(0,0,0,0.15);

}

.policy-item{

background:#f6fbff;

border:1px solid #cfe2ee;

border-radius:14px;

padding:18px;

box-shadow:0 6px 18px rgba(8,47,66,0.05);

}

.section{

padding:34px 30px;

}

.card,
.package-card,
.policy-item{

transition:all .2s ease;

}

.card:hover{

transform:translateY(-2px);

}

.price-chip{

font-size:18px;

}

.price-chip small{

font-size:11px;

}

.price-chip{

font-weight:700;

letter-spacing:0.03em;

}

.exclusive-label{

font-size:12px;

color:#cfe8f7

letter-spacing:0.05em;

text-transform:uppercase;

margin-bottom:10px;

}

.package-card h3{

font-size:22px;

margin-bottom:10px;

}

.hero{

position:relative;

min-height:85vh;

display:flex;

align-items:center;

justify-content:center;

background-image:url("https://images.unsplash.com/photo-1507525428034-b723cf961d3e");

background-size:cover;

background-position:center;

}

.hero-overlay{

position:absolute;

top:0;

left:0;

width:100%;

height:100%;

background:linear-gradient(
180deg,
rgba(8,47,66,0.55),
rgba(8,47,66,0.75)
);

}

.hero-card{

position:relative;

background:rgba(8,47,66,0.75);

padding:50px;

border-radius:18px;

max-width:700px;

text-align:center;

color:white;

backdrop-filter:blur(6px);

box-shadow:0 25px 60px rgba(0,0,0,0.25);

}

.hero-card h1{

font-size:42px;

margin-bottom:15px;

}

.hero-card p{

font-size:18px;

opacity:0.9;

margin-bottom:25px;

}

/* FLOATING BOOK BUTTON */

.floating-book{

position:fixed;

bottom:20px;

right:20px;

display:flex;

flex-direction:column;

gap:10px;

z-index:999;

}

.floating-book a{

padding:12px 18px;

border-radius:999px;

font-weight:600;

box-shadow:0 10px 25px rgba(0,0,0,0.25);

text-decoration:none;

}

.floating-book a:hover{

transform:translateY(-2px);

box-shadow:0 14px 30px rgba(0,0,0,0.3);

}

/* Announcement Bar */

.announcement-bar{

background:#0f3f58;

color:white;

text-align:center;

padding:8px;

font-size:14px;

font-weight:500;

letter-spacing:0.5px;

}

/* AMENITIES SECTION */

.amenities-grid{

display:grid;

grid-template-columns:repeat(auto-fit,minmax(220px,1fr));

gap:18px;

margin-top:20px;

}

.amenity{

background:#f1f6f9;

padding:18px;

border-radius:12px;

font-weight:500;

text-align:center;

border:1px solid #d9e5ec;

transition:0.2s;

}

.amenity:hover{

transform:translateY(-3px);

box-shadow:0 10px 20px rgba(0,0,0,0.08);

}

/* GALLERY */

.gallery-grid{

display:grid;

grid-template-columns:repeat(auto-fit,minmax(250px,1fr));

gap:20px;

margin-top:25px;

}

.gallery-placeholder{

background:#e7eef3;

border:1px dashed #b6c9d6;

border-radius:14px;

height:180px;

display:flex;

align-items:center;

justify-content:center;

font-weight:500;

color:#4c6677;

}

/* MOBILE NAVIGATION */

@media (max-width: 600px){

.site-nav{
flex-direction:column;
align-items:flex-start;
width:100%;
gap:6px;
margin-top:10px;
}

.site-nav a{
display:block;
width:100%;
}

.header-wrap{
flex-direction:column;
align-items:flex-start;
}

}

/* MOBILE HERO */

@media (max-width:600px){

.hero{
padding:60px 15px;
}

.hero-card{
padding:20px;
}

.hero h1{
font-size:28px;
}

.hero p{
font-size:14px;
}

}

/* MOBILE PACKAGES */

@media (max-width:600px){

.price-row{
grid-template-columns:1fr;
}

.package-card{
padding:18px;
}

}

@media (max-width:680px){

.floating-book{
position:fixed;
bottom:10px;
left:10px;
right:10px;
flex-direction:row;
justify-content:center;
gap:10px;
}

.floating-book .btn{
flex:1;
text-align:center;
}

}

/* MOBILE SECTIONS */

@media (max-width:600px){

.section{
padding:20px 15px;
}

.grid-2,
.grid-3{
grid-template-columns:1fr;
}

}

/* MOBILE NAVIGATION */

@media (max-width:700px){

.site-nav{

display:grid;

grid-template-columns:repeat(3,1fr);

gap:6px;

width:100%;

}

.site-nav a{

text-align:center;

padding:10px 6px;

font-size:13px;

}

.header-wrap{

flex-direction:column;

align-items:flex-start;

}

}