
:root{
  --primary:#1a56db;
  --primary-dark:#0f3fa6;
  --text:#1e2a39;
  --muted:#6b7280;
  --bg:#f6f9ff;
  --card:#ffffff;
  --line:#e6ecf5;
  --shadow:0 18px 40px rgba(16, 44, 112, .08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#ffffff 0%, #f7f9ff 100%);
}
a{text-decoration:none;color:inherit}
.container{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  min-height:72px;
  display:flex; align-items:center; gap:24px; justify-content:space-between;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-logo{
  width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--primary),#47a3ff);
  color:#fff; display:grid; place-items:center; font-size:20px; box-shadow:var(--shadow)
}
.brand-name{font-weight:800;line-height:1.1}
.brand-sub{font-size:12px;color:var(--muted)}
.menu{display:flex; gap:22px; color:#334155; font-weight:500}
.menu a{opacity:.85}
.menu a:hover{color:var(--primary)}
.actions{display:flex; gap:10px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:14px; padding:12px 18px; font-weight:700; border:1px solid transparent;
}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark)); color:#fff}
.btn-outline{background:#fff; border-color:var(--line); color:#1f2d3d}
.hero{
  position:relative;
  min-height:760px;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(11, 75, 158, .48), rgba(11, 75, 158, .15)),
    url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(7,35,82,.65) 0%, rgba(7,35,82,.18) 60%, rgba(7,35,82,.0) 100%);
}
.hero-content{position:relative; z-index:1; padding:72px 0 84px; color:#fff}
.hero-badge{
  display:inline-flex; padding:10px 16px; border-radius:999px;
  background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.25);
  font-size:14px; backdrop-filter:blur(8px); margin-bottom:18px
}
.hero h1{
  font-size:clamp(44px, 6vw, 84px);
  line-height:1.02; margin:0 0 14px; letter-spacing:-.04em; max-width:700px
}
.hero p{max-width:660px; font-size:17px; line-height:1.75; color:rgba(255,255,255,.9); margin:0 0 24px}
.hero-tabs{display:flex; gap:10px; margin-bottom:18px}
.tab{
  background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.18);
  border-radius:12px; padding:10px 16px; font-weight:600
}
.tab.active{background:#fff; color:var(--primary)}
.search-box{
  display:grid; grid-template-columns:repeat(3,1fr) auto;
  gap:12px; background:#fff; padding:16px; border-radius:24px; box-shadow:var(--shadow);
  max-width:900px; margin-top:22px;
}
.field{background:#fff; border:1px solid var(--line); border-radius:16px; padding:12px 14px}
.field label{display:block; font-size:12px; color:var(--muted); margin-bottom:6px}
.field input,.booking-form input,.booking-form select,.booking-form textarea,.newsletter-form input{
  width:100%; border:0; outline:0; font:inherit; color:var(--text); background:transparent
}
.btn-search{min-width:140px; border-radius:16px}
.section{padding:72px 0 0}
.section-head{
  display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:24px
}
.eyebrow{
  display:inline-block; font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase;
  color:var(--primary); margin-bottom:8px
}
.section h2{font-size:clamp(28px, 3vw, 42px); margin:0}
.link{color:var(--primary); font-weight:700}
.card-row{display:grid; gap:18px}
.card-row.four{grid-template-columns:repeat(4,1fr)}
.travel-card{
  background:var(--card); border:1px solid var(--line); border-radius:22px; overflow:hidden;
  box-shadow:var(--shadow);
}
.travel-card img{width:100%; height:190px; object-fit:cover; display:block}
.travel-card-body{padding:16px}
.travel-card-body h3{margin:0 0 6px; font-size:18px}
.travel-card-body p{margin:0 0 10px; color:var(--muted); font-size:14px}
.rating,.price{font-weight:800; color:#111827}
.price span{font-weight:500; color:var(--muted); font-size:14px}
.property{position:relative}
.badge{
  position:absolute; top:14px; left:14px; z-index:1;
  background:#ff8c2a; color:#fff; padding:6px 10px; border-radius:999px; font-size:11px; font-weight:800
}
.service-layout{
  display:grid; grid-template-columns:1.05fr .95fr; gap:34px; align-items:center
}
.service-visual{position:relative; min-height:460px}
.visual-card{
  position:absolute; overflow:hidden; border-radius:28px; box-shadow:var(--shadow); border:8px solid rgba(255,255,255,.85)
}
.visual-card img{width:100%; height:100%; object-fit:cover; display:block}
.visual-card.large{left:0; top:20px; width:72%; height:320px}
.visual-card.overlap{right:4%; bottom:0; width:58%; height:280px}
.service-copy p{color:var(--muted); line-height:1.8}
.service-list{display:grid; gap:16px; margin-top:22px}
.service-item{
  display:flex; gap:14px; align-items:flex-start; background:#fff; border:1px solid var(--line);
  padding:16px; border-radius:20px; box-shadow:var(--shadow)
}
.service-item span{font-size:24px}
.service-item p{margin:4px 0 0}
.blog-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:18px}
.blog-feature,.newsletter-card,.booking-card,.payment-card,.info-box,.testimonial{
  background:#fff; border:1px solid var(--line); border-radius:26px; box-shadow:var(--shadow)
}
.blog-feature img{width:100%; height:330px; object-fit:cover; border-top-left-radius:26px; border-top-right-radius:26px}
.blog-body{padding:18px}
.blog-body h3{margin:0 0 10px; font-size:22px}
.meta{color:var(--muted); font-size:13px}
.blog-list{display:grid; gap:14px}
.blog-item{display:grid; grid-template-columns:120px 1fr; gap:12px; align-items:center; background:#fff; border:1px solid var(--line); padding:10px; border-radius:20px}
.blog-item img{width:120px;height:86px;object-fit:cover;border-radius:14px}
.blog-item h4{margin:0 0 6px; font-size:15px}
.blog-item p{margin:0; color:var(--muted); font-size:13px}
.newsletter-card{
  padding:26px;
  min-height:240px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  background:linear-gradient(135deg, #163c82, #1259d1), url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1400&q=80') center/cover no-repeat;
  color:#fff;
}
.newsletter-card p{color:rgba(255,255,255,.88); max-width:560px}
.newsletter-form{
  display:flex; gap:12px; align-items:center; background:#fff; padding:10px;
  border-radius:16px; min-width:min(420px,100%); box-shadow:var(--shadow)
}
.newsletter-form input{padding:10px 12px}
.booking-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:20px}
.booking-card{padding:26px}
.booking-form{display:grid; gap:14px; margin-top:16px}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.booking-form input,.booking-form select,.booking-form textarea{
  border:1px solid var(--line); border-radius:16px; padding:14px 16px; background:#fbfcff
}
.booking-side{display:grid; gap:16px}
.info-box{padding:22px}
.bank-list{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.bank-list span{background:#eef4ff; color:var(--primary); border-radius:999px; padding:8px 12px; font-weight:700}
.info-box ul{margin:12px 0 0; padding-left:18px; color:#334155; line-height:1.8}
.payment-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:18px}
.payment-card{padding:26px}
.rekening{display:grid; gap:14px; margin-top:18px}
.rekening div{display:flex; justify-content:space-between; border:1px dashed var(--line); padding:14px 16px; border-radius:16px}
.qris-box{
  margin-top:16px; display:grid; place-items:center; min-height:240px;
  border-radius:22px; background:#f8fbff; border:1px solid var(--line)
}
.qris-box img{width:220px;height:220px}
.testimonial-strip{display:grid; gap:14px; grid-template-columns:repeat(3,1fr)}
.testimonial{padding:18px; display:flex; gap:14px; align-items:flex-start}
.avatar{
  width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--primary),#50a5ff); color:#fff; font-weight:800
}
.testimonial p{margin:6px 0 0; color:#475569; line-height:1.7}
.footer{
  margin-top:72px; background:#08132c; color:#e5eefc; padding:34px 0 18px
}
.footer-inner{
  display:flex; align-items:center; justify-content:space-between; gap:18px; padding-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.12)
}
.footer-links{display:flex; gap:18px; flex-wrap:wrap; color:#b6c6e5}
.footer-copy{text-align:center; color:#94a3b8; font-size:13px; padding-top:16px}
@media (max-width: 1100px){
  .menu{display:none}
  .card-row.four{grid-template-columns:repeat(2,1fr)}
  .service-layout,.blog-grid,.booking-grid,.payment-grid{grid-template-columns:1fr}
  .newsletter-card{flex-direction:column; align-items:flex-start}
  .newsletter-form{min-width:0; width:100%}
  .testimonial-strip{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .nav{gap:12px}
  .actions{display:none}
  .hero{min-height:auto}
  .hero-content{padding:56px 0 72px}
  .hero h1{font-size:40px}
  .search-box,.grid-2{grid-template-columns:1fr}
  .card-row.four{grid-template-columns:1fr}
  .section{padding-top:56px}
  .footer-inner{flex-direction:column; align-items:flex-start}
  .blog-item{grid-template-columns:1fr}
  .blog-item img{width:100%}
}
