:root{
  --cb-primary:#0b5fa5;
  --cb-primary-dark:#084b82;
  --cb-ocean:#1e88e5;
  --cb-sky:#eaf6ff;
  --cb-soft:#f8fbff;
  --cb-sand:#f6efe4;
  --cb-text:#16324f;
  --cb-muted:#5d748f;
  --cb-border:rgba(11,95,165,.12);
  --cb-shadow:0 12px 30px rgba(14, 54, 96, .12);
  --cb-radius:18px;
  --bs-primary:#0b5fa5;
  --bs-link-color:#0b5fa5;
  --bs-link-hover-color:#084b82;
}

html, body{
  scroll-behavior:smooth;
}

body{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--cb-text);
  background:
    radial-gradient(1200px 400px at 10% -5%, rgba(30,136,229,.12), transparent 60%),
    radial-gradient(800px 300px at 90% 0%, rgba(11,95,165,.08), transparent 65%),
    linear-gradient(#fafdff, #f6fbff 45%, #f9fcff);
}

h1,h2,h3,h4,h5,h6,.brand-serif{
  font-family: "Playfair Display", Georgia, serif;
  letter-spacing: .2px;
}

a{ text-decoration: none; }

.section{
  padding: 4.5rem 0;
}

.section-sm{
  padding: 3rem 0;
}

.section-title{
  margin-bottom: .6rem;
  font-size: clamp(1.7rem, 2vw, 2.35rem);
}

.section-lead{
  color: var(--cb-muted);
  max-width: 760px;
}

.top-strip{
  background: linear-gradient(90deg, #0b5fa5, #1e88e5);
  color: rgba(255,255,255,.95);
  font-size: .92rem;
}

.top-strip .small-link{
  color: rgba(255,255,255,.95);
}

.navbar-wrap{
  position: sticky;
  top: 0;
  z-index: 1030;
  backdrop-filter: blur(8px);
  background: rgba(255,255,255,.88);
  border-bottom: 1px solid rgba(11,95,165,.08);
}

.navbar-brand{
  font-family: "Playfair Display", Georgia, serif;
  font-size: 2.15rem;
  line-height: 1;
  font-weight: 700;
  color: var(--cb-primary) !important;
}

.brand-wave{
  display: block;
  width: 84px;
  height: 8px;
  border-radius: 999px;
  margin-top: 2px;
  background: linear-gradient(90deg, #5dc6ff, #1e88e5, #0b5fa5);
  opacity: .8;
}

.nav-link{
  color: #203a56 !important;
  font-weight: 500;
}
.nav-link.active{
  color: var(--cb-primary) !important;
}
.navbar .btn-sm{
  border-radius: 999px;
}

.audience-pills .btn{
  border-radius: 999px;
  font-size: .85rem;
  padding-inline: .85rem;
}

.hero{
  position: relative;
  min-height: clamp(520px, 70vh, 760px);
  display: grid;
  align-items: center;
  overflow: clip;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05) 0, rgba(255,255,255,.55) 70%, rgba(249,252,255,.95) 100%),
    radial-gradient(650px 300px at 20% 70%, rgba(110,200,255,.18), transparent 70%),
    url('https://images.unsplash.com/photo-1570077188670-e3a8d69ac5ff?auto=format&fit=crop&w=1800&q=80') center/cover no-repeat;
}
.hero::before{
  content:"";
  position:absolute; inset:auto -5% -60px -5%;
  height: 190px;
  background:
    radial-gradient(80% 160px at 30% 100%, rgba(255,255,255,.95) 45%, transparent 46%),
    radial-gradient(70% 150px at 70% 100%, rgba(255,255,255,.97) 48%, transparent 49%);
  pointer-events:none;
}
.hero-overlay-card{
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(255,255,255,.65);
  box-shadow: 0 14px 30px rgba(21,66,110,.15);
  border-radius: 22px;
  backdrop-filter: blur(8px);
}
.hero h1{
  font-size: clamp(2.15rem, 5vw, 4rem);
  line-height: .95;
  margin-bottom: .75rem;
}
.hero .subtitle{
  font-size: clamp(1rem, 1.4vw, 1.25rem);
  color: #24496a;
}
.hero .cta-wrap .btn{
  min-width: 190px;
  border-radius: 14px;
  padding: .8rem 1rem;
  box-shadow: 0 8px 18px rgba(11,95,165,.15);
}
.hero-badges .badge{
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  color: #224364;
  border: 1px solid rgba(11,95,165,.08);
  font-weight: 500;
}

.glass-card{
  background: rgba(255,255,255,.8);
  border: 1px solid rgba(255,255,255,.85);
  border-radius: 20px;
  box-shadow: var(--cb-shadow);
}

.split-journey{
  margin-top: -80px;
  position: relative;
  z-index: 3;
}

.journey-card{
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(11,95,165,.1);
  box-shadow: var(--cb-shadow);
  height: 100%;
}
.journey-cover{
  height: 160px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.journey-cover::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.95) 95%);
}
.cover-guests{
  background-image: url('https://images.unsplash.com/photo-1500375592092-40eb2168fd21?auto=format&fit=crop&w=1200&q=80');
}
.cover-owners{
  background-image: url('https://images.unsplash.com/photo-1564013799919-ab600027ffc6?auto=format&fit=crop&w=1200&q=80');
}
.journey-icon{
  width: 58px; height: 58px;
  border-radius: 16px;
  display:grid; place-items:center;
  font-size: 1.35rem;
  color: var(--cb-primary);
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(11,95,165,.1);
  box-shadow: 0 10px 18px rgba(11,95,165,.12);
}
.journey-list{
  list-style:none;
  padding-left:0;
  margin:0;
}
.journey-list li{
  display:flex;
  gap:.6rem;
  align-items:flex-start;
  margin-bottom:.55rem;
  color:#24415f;
}
.journey-list i{
  color: #1565c0;
  margin-top: .15rem;
}

.icon-grid{
  display:grid;
  gap:1rem;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
@media (min-width: 576px){
  .icon-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (min-width: 992px){
  .icon-grid{ grid-template-columns: repeat(6, minmax(0,1fr)); }
}
.icon-item{
  background:#fff;
  border:1px solid var(--cb-border);
  border-radius:16px;
  padding:1rem;
  text-align:center;
  box-shadow: 0 8px 16px rgba(8,75,130,.05);
}
.icon-item .icon{
  width:46px; height:46px; margin:0 auto .75rem;
  border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(180deg, #e8f4ff, #f7fbff);
  color: var(--cb-primary);
  font-size:1.1rem;
  border:1px solid rgba(11,95,165,.12);
}
.icon-item p{
  margin:0;
  font-size:.93rem;
  color:#304d69;
  line-height:1.25;
}

.property-card{
  border-radius: 16px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--cb-border);
  box-shadow: 0 10px 24px rgba(9,65,116,.08);
  height:100%;
}
.property-thumb{
  aspect-ratio: 4 / 2.6;
  background-size: cover;
  background-position: center;
}
.property-body{
  padding: .95rem 1rem 1rem;
}
.property-tag{
  border-radius: 999px;
  background: #edf6ff;
  color: var(--cb-primary);
  border:1px solid rgba(11,95,165,.12);
  font-size: .75rem;
  padding: .25rem .6rem;
}

.divider-wave{
  height: 70px;
  background:
    radial-gradient(55px 35px at 25px 35px, rgba(11,95,165,.08) 50%, transparent 51%) repeat-x;
  background-size: 110px 70px;
  opacity: .7;
}

.feature-strip{
  background: linear-gradient(180deg, rgba(11,95,165,.03), rgba(11,95,165,.06));
  border:1px solid rgba(11,95,165,.07);
  border-radius: 20px;
  box-shadow: 0 12px 20px rgba(9,65,116,.04);
}

.check-list{
  list-style:none;
  padding-left:0;
  margin:0;
}
.check-list li{
  margin-bottom:.7rem;
  color:#2a4763;
}
.check-list i{
  color:#1e88e5;
  margin-right:.5rem;
}

.banner-panel{
  border-radius: 22px;
  padding: 1.5rem;
  background:
    linear-gradient(140deg, rgba(255,255,255,.95), rgba(255,255,255,.82)),
    url('https://images.unsplash.com/photo-1519046904884-53103b34b206?auto=format&fit=crop&w=1500&q=80') center/cover;
  border: 1px solid rgba(11,95,165,.1);
  box-shadow: var(--cb-shadow);
}

.page-hero{
  padding: 4rem 0 3rem;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(249,252,255,.95)),
    url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1800&q=80') center/cover no-repeat;
}
.page-hero .hero-shell{
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.85);
  border-radius: 22px;
  box-shadow: var(--cb-shadow);
  backdrop-filter: blur(7px);
}

.breadcrumb{
  --bs-breadcrumb-divider-color:#6d86a1;
  --bs-breadcrumb-item-active-color:#48637f;
}

.card-soft{
  background:#fff;
  border:1px solid var(--cb-border);
  border-radius:18px;
  box-shadow:0 10px 22px rgba(9,65,116,.05);
}

.service-row{
  border:1px solid rgba(11,95,165,.08);
  border-radius: 16px;
  background:#fff;
  padding:1rem;
  height:100%;
  box-shadow: 0 8px 18px rgba(8,75,130,.04);
}
.service-row .service-icon{
  width:52px; height:52px;
  border-radius:14px;
  display:grid; place-items:center;
  background:#eef6ff;
  border:1px solid rgba(11,95,165,.14);
  color:var(--cb-primary);
  font-size:1.15rem;
  flex-shrink:0;
}
.service-row p{
  margin-bottom:0;
  color:#56708c;
}

.timeline{
  position:relative;
  padding-left: 1rem;
}
.timeline::before{
  content:"";
  position:absolute;
  left:.45rem; top:.2rem; bottom:.2rem;
  width:2px; background:rgba(11,95,165,.12);
}
.timeline-step{
  position:relative;
  padding-left:1.25rem;
  margin-bottom:1rem;
}
.timeline-step::before{
  content:"";
  position:absolute; left:-.02rem; top:.3rem;
  width:10px; height:10px;
  border-radius:50%;
  background: var(--cb-ocean);
  box-shadow: 0 0 0 4px rgba(30,136,229,.14);
}

.pricing-card{
  border:1px solid rgba(11,95,165,.1);
  border-radius:20px;
  background:#fff;
  box-shadow: var(--cb-shadow);
  height:100%;
}
.pricing-card.featured{
  border-color: rgba(30,136,229,.28);
  transform: translateY(-4px);
}
.pricing-badge{
  border-radius:999px;
  background:#ecf5ff;
  color:var(--cb-primary);
  border:1px solid rgba(11,95,165,.15);
}

.contact-card{
  background:#fff;
  border:1px solid var(--cb-border);
  border-radius:18px;
  box-shadow: var(--cb-shadow);
}

.form-control, .form-select{
  border-radius: 12px;
  border-color: rgba(11,95,165,.12);
  padding: .75rem .9rem;
}
.form-control:focus, .form-select:focus{
  border-color: rgba(30,136,229,.35);
  box-shadow: 0 0 0 .25rem rgba(30,136,229,.12);
}
.btn{
  border-radius: 12px;
}
.btn-primary{
  background: linear-gradient(180deg, var(--cb-primary), var(--cb-primary-dark));
  border-color: var(--cb-primary-dark);
}
.btn-outline-primary{
  border-color: rgba(11,95,165,.35);
  color: var(--cb-primary);
}
.btn-outline-primary:hover{
  background: rgba(11,95,165,.06);
  color: var(--cb-primary-dark);
  border-color: rgba(11,95,165,.5);
}

.footer{
  background:
    linear-gradient(180deg, rgba(11,95,165,.04), rgba(11,95,165,.09)),
    radial-gradient(600px 200px at 80% 20%, rgba(30,136,229,.11), transparent 70%);
  border-top: 1px solid rgba(11,95,165,.08);
}
.footer-logo{
  font-family:"Playfair Display", Georgia, serif;
  font-size:2.1rem;
  line-height:1;
  color:var(--cb-primary);
  font-weight:700;
}
.footer a{
  color:#345471;
}
.footer .social a{
  width:36px; height:36px;
  display:grid; place-items:center;
  border-radius:10px;
  border:1px solid rgba(11,95,165,.12);
  background: rgba(255,255,255,.7);
}

.badge-soft{
  background:#eef6ff;
  color:#1a4e81;
  border:1px solid rgba(11,95,165,.12);
  border-radius:999px;
  padding:.35rem .6rem;
  font-weight:500;
}

.map-placeholder{
  min-height: 300px;
  border-radius: 16px;
  border: 1px solid rgba(11,95,165,.1);
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.92)),
    url('https://images.unsplash.com/photo-1519046904884-53103b34b206?auto=format&fit=crop&w=1200&q=80') center/cover;
  box-shadow: 0 10px 22px rgba(9,65,116,.08);
}

.tag-list{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}

.cta-band{
  background: linear-gradient(100deg, rgba(11,95,165,.95), rgba(30,136,229,.92));
  color:#fff;
  border-radius:20px;
  box-shadow:0 14px 28px rgba(11,95,165,.18);
}
.cta-band .btn-light{
  color: var(--cb-primary);
  font-weight:600;
}
.cta-band .btn-outline-light{
  border-color: rgba(255,255,255,.75);
}

.sticky-side{
  position: sticky;
  top: 96px;
}

.list-clean{
  list-style:none;
  padding-left:0;
}
.list-clean li{
  padding:.45rem 0;
  border-bottom:1px dashed rgba(11,95,165,.08);
}

.table-soft{
  --bs-table-bg: transparent;
  --bs-table-striped-bg: rgba(11,95,165,.02);
}
.table-soft thead th{
  color:#365675;
  font-weight:600;
}

.hero-mini{
  height: 240px;
  border-radius: 18px;
  overflow: hidden;
  background: url('https://images.unsplash.com/photo-1499793983690-e29da59ef1c2?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
  border:1px solid rgba(11,95,165,.1);
  box-shadow: var(--cb-shadow);
}

.offcanvas{
  --bs-offcanvas-width: 320px;
}
.offcanvas .nav-link{
  padding: .7rem 0;
}

.mobile-cta{
  position: sticky;
  bottom: 0;
  z-index: 1020;
  background: rgba(255,255,255,.93);
  backdrop-filter: blur(8px);
  border-top: 1px solid rgba(11,95,165,.1);
  box-shadow: 0 -10px 20px rgba(8,75,130,.06);
}

@media (max-width: 767.98px){
  .section{
    padding: 3.25rem 0;
  }
  .hero{
    min-height: 600px;
    align-items: end;
    padding-bottom: 4rem;
    background-position: 58% center;
  }
  .split-journey{
    margin-top: -45px;
  }
  .hero-overlay-card{
    border-radius: 18px;
  }
  .hero .cta-wrap .btn{
    width: 100%;
  }
  .navbar-brand{
    font-size: 1.9rem;
  }
}


/* Brand image overrides (navbar + footer) */
.brand-logo-img{
  display:block;
  width:auto;
  max-width:100%;
  object-fit:contain;
}
.navbar-brand{
  display:inline-flex;
  align-items:center;
}
.navbar-brand .brand-logo-img{
  height:44px;
}
.offcanvas-header .navbar-brand{
  color: transparent !important;
  font-size: 0;
  line-height: 0;
}
.offcanvas-header .navbar-brand .brand-logo-img{
  height:42px;
}
.footer-logo{
  display:inline-flex;
  align-items:center;
}
.footer-logo .brand-logo-img{
  height:52px;
}

@media (max-width: 767.98px){
  .navbar-brand .brand-logo-img{
    height:38px;
  }
  .offcanvas-header .navbar-brand .brand-logo-img{
    height:36px;
  }
  .footer-logo .brand-logo-img{
    height:46px;
  }
}
