body{
	background: #f6f7fb;
}
.homeheaderimg{
	background: url(../assets/bgheader.png) no-repeat center center, linear-gradient(rgba(0,0,0,0.5),rgba(0,0,0,0.5));
	background-size:cover ;
	border-bottom-left-radius: 24px;
	border-bottom-right-radius: 24px;
}
.yellowbtn{
	background: #FFD53F;
	color: #262626;
	border-radius: 12px;
	width:125px;
	display: block;
	font-size: 14px;
	font-weight: 400;
	line-height: 21.79px;
	text-align: center;
	text-underline-position: from-font;
	text-decoration-skip-ink: none;
    padding: 10px;
    text-decoration: none;
}
.mobile-details-btn{
	display: inline-block;
	padding: 5px 10px;
	font-size: 13px;
	line-height: 1.4;
	border-radius: 8px;
	background: #FFD53F;
	border: none;
	float: right;
}
.greybtn{
	background: #1b1b1b8f;
	color: #fff;
	border-radius: 12px;
	width:125px;
	display: block;
	font-size: 14px;
	font-weight: 400;
	line-height: 21.79px;
	text-align: center;
	text-underline-position: from-font;
	text-decoration-skip-ink: none;
}
.ml10{
	margin-left: 10px;
}
.homesearch{
    display: block;
    width: 100%;
    margin: auto;
    background: #fff;
    padding: 20px;
    border-radius: 40px;
    max-width: 854px;
    position: relative;
}
.homesearch label {
	color: #222;
	text-align: left;
	width: 100%;
}
.homesearch .guestsdiv{
	text-align: left;
	width: 100%;	
}
.homeinput {
       display: inline-block;
    width: 30%;
    border-right: 1px solid #999;
    margin-right: 1%;
}
.searchinput {
       display: inline-block;
    width: 22.5%;
    border-right: 1px solid #999;
    margin-right: 1%;
}
.nobdright{
	border-right: 0 !important;
}
.homeinput select,.homeinput input{
    display: block;
    border:0;
    padding:0px;
    width: 80%;
}
.searchinput select,.searchinput input{
    display: block;
    border:0;
    padding:0px;
    width: 80%;
}
.text-grey{
	color: #999999;
}

.homebutton{
    position: absolute;
    right: 10px;
    top: 10px;
}

.homebutton button{
	    border: 0px;
    background: #ffd53f;
    width: 70px;
    height: 70px;
    border-radius: 50%;
}
.homebutton button i{
	font-size: 30px;
}
.roundimg{
	    width: 64px;
    height: 64px;
    border-radius: 50%;
}
.centerimg{
	display: block;
	margin: auto;
}
.smallcol{
	display: inline-block;
	width: 10.5%;
}
.ptext{
	color: #262626;
	font-size: 14px;
	font-weight: 400;
	line-height: 19.07px;
	text-underline-position: from-font;
	text-decoration-skip-ink: none;
	text-decoration: none !important;
}
.simplelink{
	text-decoration: none;
}
section.whitecard{
	    max-width: 1140px;
    display: block;
    margin: auto;
    background: #fff;
    padding: 15px;
    border-radius: 12px;
    margin-top: 60px;
    margin-bottom: 60px;
}
.blackhead{
font-size: 28px;
font-weight: 700;
line-height:40px;
text-align: left;
}
/* Match the Top Destinations / Species section headings to the standard
   country-page section heading size (.cnp-section-h2). */
.excitingsec .blackhead,
.categorysec .blackhead { font-size: 22px; line-height: 1.3; }
.blacksmallhead{
font-size: 22px;
font-weight: 700;
line-height:40px;
text-align: left;
}
.blacksmfont{
font-size: 18px;
font-weight: 600;
line-height:24px;
text-align: left;
}
.imgcard{
	width:100%;
	height: 180px;
	object-fit: cover;
	border-radius: 	12px;
}
.image-container{
	margin-bottom: 20px;
}
.image-container .after {
       position: absolute;
    top: 0;
    left: 12px;
    width: calc(100% - 24px);
    height: 100%;
    display: block;
    background: rgba(0, 0, 0, .3);
    border-radius: 12px;
    color: #FFF;
    margin: auto;
    text-align: center;

}
.image-container:hover .after {
}
.posrelative{
	position: relative;
}
span.locationtext {
    position: absolute;
    top: 15px;
    color: #fff;
    left: 20px;
}
.nametext {
    position: absolute;
    bottom: 15px;
    color: #fff;
    left: 20px;font-size: 24px;
	font-weight: 700;
	line-height: 32.68px;
	text-align: left;
	text-underline-position: from-font;
	text-decoration-skip-ink: none;
}
.nametext h3 { margin: 0; font: inherit; }
.chartertext{
font-size: 14px;
font-weight: 400;
line-height: 19.07px;
text-align: left;

}
.catnametext{
    position: absolute;
    bottom: 15px;
    color: #fff;
    left: 20px;
font-size: 20px;
font-weight: 700;
line-height: 27.24px;
text-align: left;
margin: 0;
}
.brdrwhiteheader{
	border-bottom: 1px solid #fff;
    padding-bottom: 10px;
    padding-left: 0px;
    padding-right: 0px;
}
.footer ul li {
	list-style: none;
}
.footer ul li a{
	text-decoration: none;
	color: #262626;
	font-size: 12px;
	list-style: none;
	padding-left:0px ;
	font-weight: 400;
	line-height: 16.34px;
	text-align: left;
	text-underline-position: from-font;
	text-decoration-skip-ink: none;
}
.footer ul {
	padding: 0px;
}
.copyright p{
	color: #999999;
	font-size: 14px;
	font-weight: 400;
	line-height: 19.07px;
	text-align: center;
	text-underline-position: from-font;
	text-decoration-skip-ink: none;
}
.footer .social-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid #262626;
    font-size: 16px;
    color: #262626;
    margin-right: 10px;
    transition: 0.3s;
}
.payment-links i {
    color: #262626;
    padding: 10px;
}
.rbigtext{
font-size: 24px;
font-weight: 700;
line-height: 32.68px;
text-align: left;

color: #FFFFFF;
}
.topposabs{
	position: absolute;
	top:10px;
width: 95%;
left:20px;
}
.staricon {
    color: gold;
}
.ratings{
font-size: 22px;
font-weight: 600;
line-height: 29.96px;
text-align: left;

}
.tleft{
	text-align: left;
}
.bgimagecontainer{
	    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 12px;
    background-position: center center;
    box-shadow: inset 0 0 0 2000px rgba(0, 0, 0, .3);
    width: calc(50% - 10px);
    display: block;
    margin: auto;
    height: 180px;
}
.mb-0{
	margin-bottom: 0px;
}
.flright{
	float: right;
}
.sortoptions{
	display: inline-block;
	width: 94%;
}
.sortoptions li{
	display: inline-block;
    width: 23%;
    margin-right: 1%;
    text-align: center;
    font-weight: 600;
    background: #fff;
    border-radius: 12px;
    padding: 5px 10px;
    cursor: pointer;
}
.sortoptions li.active{
	background: #E0F4FD;
}
.tripoptions{
    display: inline-block;
    width: 100%;
    padding-left: 0px;
    text-align: center;
}
.tripoptions li{
    display: inline-block;
    width: max-content;
    margin-right: 10px;
    text-align: center;
    font-weight: 600;
    background: #fff;
    border-radius: 16px;
    padding: 5px 12px;
    cursor: pointer;
}
.tripoptions li.active{
    background: #E0F4FD;
}
.searchdiv img.imgcard {
	border-radius: 12px;
	height: 160px;
}
.lname {
font-size: 18px;
font-weight: 700;
line-height: 27.24px;
text-align: left;
}
.lrating{
font-size: 14px;
font-weight: 600;
line-height: 27.24px;
text-align: left;
display: block;
}
.fs16{
	font-size: 16px !important;
	 width: 20px;
    height: 20px;
}
.shipimg{
	width: 80px;
	height: auto;
}
.text-right{
	text-align: right;
}
.lfeatures{
font-size: 14px;
font-weight: 600;
line-height: 19.07px;
text-align: left;
display: inline-block;
color: #3C763D;
}
.ltripftrs{
font-size: 14px;
font-weight: 600;
line-height: 19.07px;
text-align: left;
display: inline-block;
color: #262626;
padding-right:10px ;
border-right:1px solid #E2E2E2;
}

.lprice{
font-size: 18px;
font-weight: 800;
line-height: 24.51px;
text-align: left;
color: #3C763D;
}
.lbutton{
	width: 100%;
	padding: 12px;
	color: #262626;
	font-size: 14px;
	font-weight: 600;
	line-height: 21.79px;
	text-align: center;
}
.searchresults{
	margin-top: 40px;
	margin-bottom: 60px;
}
.innerbox {
    padding: 15px;
    background: #fff;
    border-radius: 12px;
    margin-bottom:20px;
}

.progress-steps .top {
    margin-bottom: 30px;
    position: relative;
}
.progress-steps .top .progressfirst {
    width: 50%;
    height: 3px;
    background-color:#1DA8FF;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    z-index: -1;
}
.progress-steps .top .progresssecond {
    width: 50%;
    height: 3px;
    background-color:#ccc;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%);
    z-index: -1;
}
.progress-steps .top .progress span {
    position: absolute;
    width: 0%;
    height: 100%;
    left: 0px;
    top: 0px;
    background: #3498db;
    transition: 0.5s;
}
.progress-steps .top .steps {
    display: flex;
    justify-content: space-between;
}
.progress-steps .top .steps .step {
     background-color: white;
    border: 3px solid #e0e0e0;
    border-radius: 50%;
    height: 35px;
    cursor: pointer;
    width: 35px;
    text-align: center;
    line-height: 30px;
    font-size: 16px;
    font-weight: 700;
}
.stext {
    display: inline-block;
    width: 33%;
}
.progress-steps .top .steps .step.active {
	border-color: #1DA8FF;
    transition: border 1s;
    background: #1DA8FF;
    color: #fff;
}

.progress-steps .buttons {
    display: flex;
    justify-content: center;
    gap: 0px 20px;
}

.progress-steps .buttons .btn {
    outline: 0px;
    border: 0px;
    padding: 10px 25px;
    border-radius: 5px;
    cursor: pointer;
    background-color: #3498db;
    font-weight: bold;
    color: white;
    transition: color 0.5s;
}

.progress-steps .buttons .btn.disabled {
    background-color: #e0e0e0;
    color: #bdbdbd;
    cursor: no-drop;
}
.formwhitecard{
    background: #fff;
    padding: 15px;
    border-radius: 12px;
}
.circleimg{
	height: 80px;
	width:80px;
	border-radius: 50%;
	display: block;
	margin: auto;
}
.messagehead{
font-size: 20px;
font-weight: 600;
line-height: 27.24px;
text-align: left;
}
.mt-36{
	margin-top:36px;
}
.lefticon{
	    float: left;
    font-size: 24px;
    padding: 5px;
}
.fs24{
	font-size: 24px !important;
}
ul.shipfeatures {
	padding-left: 0px;
}
ul.shipfeatures li {
    display: inline-block;
    padding: 6px;
    background: red;
    margin: 5px;
    font-size: 12px;
    border-radius: 4px;
    border: 0;
    background: #F6F7FB;
    color: #262626;
}
ul.shipfeatures li i{
	color:#1DA8FF;
}
span.tripdtls {
    display: block;
    font-size: 14px;
}
.dblock{
	display: block;
}
.text-right{
	text-align: right;
}
.totaltxt{
	font-weight: 700;
}
.greentext{
    color: #3C763D !important;
}
.redtext{
    color: #A94442 !important;
}
img.listimage {
    width: 100%;
    margin: 5px;
}
.font600{
    font-weight: 600;
}
.showmore{
        position: absolute;
    top: 5px;
    left: 16px;
    width: calc(100% - 22px);
    height: calc(100% - 10px);
    text-align: center;
    background: #80808061;
    color: #fff;
}
.smoretext{
    margin-top: 25px;
    display: inline-block;
}
.wid50{
    width: 45%;
}
.wid1140{
    max-width: 1140px;
}
.widmxcontent{
    width: max-content;
}
.pl-0{
    padding-left: 0px;
}
.showmorebtn{
    color: #1DA8FF;
    font-weight: 700;
}
.disinblock {
    display: inline-block;
}
.fishimgtrip{
    width: 100%;
    height: 100px;
    border-radius: 12px;
    object-fit: cover;
}
.tripsbooking{
    margin-top: 30px !important;
    margin-bottom: 30px !important;
}
.cancelsteps .progress-steps .top .steps .step.green{
    z-index:2;
    border-color:#3C763D;
    background-color: #3C763D;
}
.cancelsteps .progress-steps .top .steps .step.red{
    z-index:2;
    border-color:#A94442;
    background-color: #A94442;
}
.cancelsteps .progress-steps .top .progressfirst{
    z-index:1;
    background-color:#3C763D;
}
.cancelsteps .progress-steps .top .progresssecond{
   z-index:1;
   background-color:#A94442;
}
.pl-15 {
    padding-left: 15px;
}
.col-xs-8r,
.col-sm-8r,
.col-md-8r,
.col-lg-8r {
    position: relative;
    min-height: 1px;
    padding-right: 15px;
    padding-left: 15px;
}

.col-xs-8r {
    width: 12.5%;
    float: left;
}

@media (min-width: 768px) {
    .col-sm-8r {
        width: 12.5%;
        float: left;
    }
}

@media (min-width: 992px) {
    .col-md-8r {
        width: 12.5%;
        float: left;
    }
}

@media (min-width: 1200px) {
    .col-lg-8r {
        width: 12.5%;
        float: left;
    }
}
@media (min-width: 1200px) {

.container{
    max-width: 1140px;
}

}

/* ═══════════════════════════════════════════════════════
   COUNTRY NEW PAGE  (.cnp-*)
═══════════════════════════════════════════════════════ */

/* Hero */
.cnp-hero {
  width: 100%;
  height: 320px;
  background-size: cover;
  background-position: center;
  background-color: #1a4a40;
}
@media (max-width: 767px) { .cnp-hero { height: 200px; } }

/* Search wrap */
.cnp-search-wrap {
  background: #fff;
  padding: 30px 0 48px;
  border-bottom: 1px solid #e8e8e8;
}
.cnp-h1 { font-size: 26px; font-weight: 700; color: #1a1a1a; margin-bottom: 4px; }
.cnp-subtitle { font-size: 14px; color: #666; margin-bottom: 0; }
.cnp-search-wrap .homesearch { margin-left: 0; max-width: 100%; }
.cnp-search-form {
  display: flex;
  gap: 0;
  border: 1px solid #ccc;
  border-radius: 8px;
  overflow: hidden;
  max-width: 860px;
}
.cnp-search-field {
  flex: 1;
  padding: 10px 14px;
  border-right: 1px solid #e0e0e0;
  display: flex;
  flex-direction: column;
}
.cnp-search-field label { font-size: 10px; font-weight: 600; color: #888; letter-spacing: 0.5px; margin-bottom: 2px; }
.cnp-search-input { border: none; outline: none; font-size: 14px; color: #222; background: transparent; padding: 0; }
.cnp-search-btn {
  background: #2a7a6c;
  color: #fff;
  border: none;
  padding: 0 28px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}
.cnp-search-btn:hover { background: #1e5e52; }
@media (max-width: 767px) {
  .cnp-search-form { flex-direction: column; border-radius: 8px; }
  .cnp-search-field { border-right: none; border-bottom: 1px solid #e0e0e0; }
  .cnp-search-btn { padding: 14px; border-radius: 0 0 8px 8px; }
}

/* Listing header */
.cnp-listing-header { padding-top: 24px; padding-bottom: 12px; }
.cnp-breadcrumb { background: none; padding: 0; margin-bottom: 12px; }
.cnp-section-h2 { font-size: 22px; font-weight: 700; color: #1a1a1a; margin-bottom: 6px; }

.cnp-listing-count { font-size: 14px; color: #555; margin-bottom: 14px; }
.cnp-showing-count { font-size: 13px; color: #777; margin-bottom: 10px; display: block; }
.cnp-sort-tab {
  padding: 5px;
  color: #1a1a1a !important;
  display: inline-block;
  width: 100%;
  text-decoration: none;
  cursor: pointer;
}

/* Charter card */
.cnp-charter-card {
  display: flex;
  gap: 0;
  border: 1px solid #e8e8e8;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 16px;
  background: #fff;
  transition: box-shadow 0.2s;
}
.cnp-charter-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.1); }
.cnp-charter-img-wrap {
  position: relative;
  flex-shrink: 0;
  width: 260px;
}
.cnp-charter-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cnp-badge-choice {
  position: absolute; top: 10px; left: 10px;
  background: #1a1a1a; color: #fff;
  font-size: 11px; font-weight: 600;
  padding: 3px 8px; border-radius: 4px;
}
.cnp-badge-new {
  background: #2a7a6c; color: #fff;
  font-size: 11px; font-weight: 600;
  padding: 2px 7px; border-radius: 4px;
  display: inline-block;
}
.cnp-charter-body { flex: 1; padding: 18px 20px; display: flex; flex-direction: column; }
.cnp-charter-meta { font-size: 12px; color: #888; margin-bottom: 8px; display: flex; gap: 14px; }
.cnp-charter-title { font-size: 17px; font-weight: 700; margin-bottom: 6px; }
.cnp-charter-title a { color: #1a1a1a; text-decoration: none; }
.cnp-charter-title a:hover { color: #2a7a6c; }
.cnp-charter-rating { font-size: 13px; color: #555; margin-bottom: 8px; }
.cnp-star-icon { color: #f59e0b; }
.cnp-star-empty { color: #ddd; }
.cnp-review-count { color: #888; }
.cnp-charter-desc { font-size: 13px; color: #555; margin-bottom: 8px; flex: 1; }
.cnp-review-quote {
  font-size: 13px; color: #666; font-style: italic;
  border-left: 3px solid #2a7a6c; padding-left: 10px;
  margin-bottom: 12px;
}
.cnp-charter-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.cnp-charter-price small { font-size: 11px; color: #888; }
.cnp-charter-price strong { font-size: 18px; color: #1a1a1a; }
.cnp-btn-avail {
  background: #2a7a6c; color: #fff;
  border-radius: 8px; padding: 10px 20px;
  font-size: 14px; font-weight: 600;
  text-decoration: none; display: inline-block;
  transition: background 0.15s;
}
.cnp-btn-avail:hover { background: #1e5e52; color: #fff; }
@media (max-width: 767px) {
  .cnp-charter-card { flex-direction: column; }
  .cnp-charter-img-wrap { width: 100%; height: 200px; }
}

/* Load more */
.cnp-loadmore-wrap { text-align: center; margin: 8px 0 32px; }
.cnp-btn-outline {
  border: 1px solid #2a7a6c;
  color: #2a7a6c;
  background: #fff;
  padding: 10px 24px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  transition: all 0.15s;
}
.cnp-btn-outline:hover { background: #2a7a6c; color: #fff; }

/* Sections */
.cnp-section { padding: 40px 0; }
.cnp-section-alt { background: #f7f7f5; padding: 40px 0; }

/* Location-style teal search band (search bar overlaps into the content below) */
.cnp-searchband { padding: 20px 0 0; }
.cnp-listing-header { margin-top: 38px; }


/* Horizontal scroll rails */
.cnp-h-scroll {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 12px;
  scrollbar-width: thin;
  scrollbar-color: #ccc transparent;
  touch-action: pan-x pan-y pinch-zoom;
}
/* iOS: disable double-tap-to-zoom on interactive areas (pinch-zoom still works). */
body,
.cnp-h-scroll a,
.searchlistinglist,
.cnp-arrow,
.cnp-btn-outline,
.cnp-faq-question { touch-action: manipulation; }
.cnp-city-card {
  flex-shrink: 0;
  width: 270px;
  padding: 0 12px;
}
.cnp-species-card-wrap {
  flex-shrink: 0;
  width: 228px;
  padding: 0 12px;
}
.cnp-h-scroll--gap0 { gap: 0; }
.cnp-h-scroll::-webkit-scrollbar { height: 5px; }
.cnp-h-scroll::-webkit-scrollbar-track { background: transparent; }
.cnp-h-scroll::-webkit-scrollbar-thumb { background: #ccc; border-radius: 3px; }

/* Destination cards */
.cnp-dest-card {
  flex-shrink: 0;
  width: 170px;
  text-decoration: none;
  color: inherit;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #e8e8e8;
  background: #fff;
  transition: box-shadow 0.15s;
}
.cnp-dest-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.cnp-dest-img-wrap { height: 110px; overflow: hidden; }
.cnp-dest-img { width: 100%; height: 100%; object-fit: cover; }
.cnp-dest-info { padding: 8px 10px; }
.cnp-dest-name { display: block; font-size: 13px; font-weight: 600; color: #1a1a1a; }
.cnp-dest-count { display: block; font-size: 12px; color: #888; }

/* Trip category cards */
.cnp-trip-card {
  flex-shrink: 0;
  width: 210px;
  text-decoration: none;
  color: inherit;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #e8e8e8;
  background: #fff;
  transition: box-shadow 0.15s;
}
.cnp-trip-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.cnp-trip-img-wrap { height: 130px; overflow: hidden; }
.cnp-trip-img { width: 100%; height: 100%; object-fit: cover; }
.cnp-trip-info { padding: 10px 12px; }
.cnp-trip-name { display: block; font-size: 13px; font-weight: 600; color: #1a1a1a; margin-bottom: 4px; }
.cnp-trip-price { display: block; font-size: 12px; color: #2a7a6c; font-weight: 600; }

/* Trip category rail — per-listing cards (city page only) */
.cnp-category-card {
  flex-shrink: 0;
  width: 270px;
  text-decoration: none;
  color: inherit;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #e8e8e8;
  background: #fff;
  display: block;
  transition: box-shadow 0.15s;
}
.cnp-category-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.cnp-cat-img-wrap { height: 160px; overflow: hidden; }
.cnp-cat-img { width: 100%; height: 100%; object-fit: cover; }

/* Boat-info pill floats over the image/body seam */
.cnp-cat-pill-wrap { position: relative; z-index: 2; margin-top: -14px; display: flex; justify-content: center; }
.cnp-cat-boatinfo {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #1a1a1a;
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 999px;
  padding: 5px 12px;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.cnp-cat-boatinfo-img { width: 45px; height: auto; object-fit: contain; }

.cnp-cat-info { padding: 10px 14px 14px; }
.cnp-cat-title {
  font-size: 15px;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cnp-cat-rating { display: block; font-size: 13px; color: #6b6b66; margin-bottom: 8px; }
.cnp-cat-rating b { color: #1a1a1a; }
.cnp-cat-rating .staricon { color: #f0a02c; }
.cnp-cat-new { font-weight: 600; color: #2a7a6c; }
.cnp-cat-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  color: #4a4a4a;
  background: #f0f0f0;
  padding: 3px 9px;
  border-radius: 999px;
  margin-bottom: 8px;
}
.cnp-cat-desc {
  font-size: 13px;
  color: #4a534f;
  line-height: 1.5;
  margin: 0 0 2px;
  height: 78px;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cnp-cat-readmore { display: block; color: #2a7a6c; font-weight: 600; font-size: 13px; margin-bottom: 12px; }
.cnp-cat-hr { border: none; border-top: 1px solid #afabab; margin: 0 0 12px; }

.cnp-cat-footer { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.cnp-cat-price { display: flex; flex-direction: column; font-size: 13px; color: #6b6b66; line-height: 1.3; white-space: nowrap; }
.cnp-cat-price-amt { font-size: 16px; font-weight: 700; color: #1a1a1a; }
.cnp-cat-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #FFD53F;
  color: #262626;
  font-weight: 600;
  font-size: 13px;
  padding: 9px 16px;
  border-radius: 12px;
  white-space: nowrap;
}

/* Species cards */
.cnp-species-card {
  flex-shrink: 0;
  width: 140px;
  text-decoration: none;
  color: inherit;
  text-align: center;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #e8e8e8;
  background: #fff;
  transition: box-shadow 0.15s;
}
.cnp-species-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.cnp-species-img-wrap { height: 100px; overflow: hidden; }
.cnp-species-img { width: 100%; height: 100%; object-fit: cover; }
.cnp-species-name { display: block; font-size: 12px; font-weight: 600; padding: 7px 4px; color: #1a1a1a; }

/* Season cards */
.cnp-season-card {
  flex-shrink: 0;
  width: 232px;
  border: 1px solid #e6e6e2;
  border-top: 3px solid #cfcfca;
  border-radius: 10px;
  padding: 16px 18px;
  background: #fff;
  transition: box-shadow .15s ease, transform .15s ease;
}
.cnp-season-card:hover { box-shadow: 0 6px 18px rgba(0,0,0,.07); transform: translateY(-2px); }
.cnp-season-top { display: flex; align-items: center; gap: 7px; margin-bottom: 10px; }
.cnp-season-icon { display: inline-flex; }
.cnp-season-badge { font-size: 11px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; padding: 3px 9px; border-radius: 999px; }
.cnp-season-month { font-size: 16px; font-weight: 700; color: #15302b; margin-bottom: 8px; }
.cnp-season-text { font-size: 13px; color: #4a534f; line-height: 1.6; margin: 0; }

.cnp-season-card--dry { border-top-color: #e0a83a; }
.cnp-season-card--dry .cnp-season-icon { color: #c4811a; }
.cnp-season-card--dry .cnp-season-badge { background: #fdf4e3; color: #7a5310; }

.cnp-season-card--wet { border-top-color: #3f86d0; }
.cnp-season-card--wet .cnp-season-icon { color: #2f6db0; }
.cnp-season-card--wet .cnp-season-badge { background: #eef4fb; color: #1c466f; }

.cnp-season-card--transition { border-top-color: #3a9a86; }
.cnp-season-card--transition .cnp-season-icon { color: #2a7a6c; }
.cnp-season-card--transition .cnp-season-badge { background: #eaf5f1; color: #1d4a40; }

/* Catch gallery */
/* Recent catches — review photo cards (FishingBooker-style) */
.cnp-catches-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; }
.cnp-catches-head .cnp-section-h2,
.cnp-catches-head .blackhead { margin-bottom: 0; }
.cnp-catches-head--lg { margin-bottom: 24px; }
.cnp-scroll-arrows { display: flex; gap: 8px; flex-shrink: 0; }
.cnp-arrow { width: 40px; height: 40px; border-radius: 50%; border: 1px solid #d8d8d4; background: #fff; color: #1a1a1a; font-size: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .15s, border-color .15s; }
.cnp-arrow:hover { background: #f2f2ef; border-color: #bdbdb8; }
.cnp-catches-scroll { gap: 16px; }
.cnp-catch-card { position: relative; flex-shrink: 0; width: 232px; height: 340px; border-radius: 16px; overflow: hidden; background: #222; box-shadow: 0 2px 10px rgba(0,0,0,.08); }
.cnp-catch-bg { width: 100%; height: 100%; object-fit: cover; display: block; }
.cnp-catch-shade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,.35) 42%, rgba(0,0,0,0) 70%); }
.cnp-catch-info { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; color: #fff; }
.cnp-catch-ago { font-size: 13px; opacity: .92; }
.cnp-catch-name { display: block; font-size: 16px; font-weight: 700; margin: 3px 0 5px; color: #fff; }
.cnp-catch-msg { font-size: 13px; line-height: 1.5; margin: 0; opacity: .95; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* Reviews */
.cnp-avg-rating { font-size: 15px; color: #555; margin-bottom: 18px; }
.cnp-review-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 767px) { .cnp-review-grid { grid-template-columns: 1fr; } }
/* Reviews as a horizontal carousel */
.cnp-reviews-scroll .cnp-review-card { flex-shrink: 0; width: 330px; white-space: normal; }
@media (max-width: 767px) { .cnp-reviews-scroll .cnp-review-card { width: 80vw; } }
.cnp-review-card {
  border: 1px solid #e8e8e8;
  border-radius: 10px;
  padding: 16px;
  background: #fff;
}
.cnp-review-header { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 10px; }
.cnp-review-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  overflow: hidden; background: #2a7a6c;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: #fff; font-weight: 700; font-size: 16px;
}
.cnp-review-avatar img { width: 100%; height: 100%; object-fit: cover; }
.cnp-review-name { font-size: 14px; font-weight: 600; color: #1a1a1a; }
.cnp-review-stars { font-size: 12px; color: #888; margin-top: 2px; }
.cnp-review-date { font-size: 11px; color: #aaa; }
.cnp-review-text { font-size: 13px; color: #555; margin-bottom: 8px; }
.cnp-review-charter { font-size: 11px; color: #2a7a6c; }

/* FAQ */
.cnp-faq-list { margin-top: 16px; }
.cnp-faq-item { border: 1px solid #e8e8e8; border-radius: 8px; margin-bottom: 8px; background: #fff; overflow: hidden; }
.cnp-faq-question {
  width: 100%; text-align: left; background: none; border: none;
  padding: 14px 16px; font-size: 14px; font-weight: 600; color: #1a1a1a;
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
}
.cnp-faq-question:hover { background: #f7f7f5; }
.cnp-faq-icon { font-size: 18px; color: #2a7a6c; flex-shrink: 0; margin-left: 10px; }
.cnp-faq-answer { padding: 0 16px 14px; font-size: 13px; color: #555; line-height: 1.6; }

/* SEO text */
.cnp-section-seo { padding: 56px 0; background: #f7f7f5; }
.cnp-section-h3 { font-size: 18px; font-weight: 700; color: #1a1a1a; margin: 32px 0 12px; padding-top: 28px; border-top: 1px solid #e0e0e0; }

.cnp-seo-text { font-size: 16px; color: #4a534f; line-height: 1.85; max-width: 760px; }
.cnp-seo-text > :first-child { margin-top: 0; }
.cnp-seo-text p { margin: 0 0 16px; }
.cnp-seo-text h2 { font-size: 22px; font-weight: 800; color: #15302b; letter-spacing: -.01em; margin: 32px 0 12px; }
.cnp-seo-text h3 { font-size: 19px; font-weight: 700; color: #15302b; margin: 26px 0 10px; }
.cnp-seo-text h4 { font-size: 16px; font-weight: 700; color: #2a7a6c; margin: 18px 0 6px; }
.cnp-seo-text strong { color: #1a1a1a; font-weight: 600; }
.cnp-seo-text a { color: #2a7a6c; text-decoration: underline; text-underline-offset: 2px; }
.cnp-seo-text a:hover { color: #1a5a4c; }

/* Lead-in first paragraph (description block only) */
.cnp-seo-text:not(.cnp-rules-box) > p:first-child { font-size: 19px; line-height: 1.7; color: #2f3b38; font-weight: 500; margin-bottom: 18px; }

/* Lists with teal markers */
.cnp-seo-text ul, .cnp-seo-text ol { padding-left: 4px; margin: 0 0 18px; list-style: none; }
.cnp-seo-text ol { counter-reset: cnp-li; }
.cnp-seo-text li { position: relative; padding-left: 26px; margin-bottom: 9px; }
.cnp-seo-text ul li::before { content: ""; position: absolute; left: 4px; top: 11px; width: 7px; height: 7px; border-radius: 50%; background: #2a7a6c; }
.cnp-seo-text ol li { counter-increment: cnp-li; }
.cnp-seo-text ol li::before { content: counter(cnp-li); position: absolute; left: 0; top: 1px; width: 20px; height: 20px; font-size: 12px; font-weight: 700; color: #1a5a4c; background: #e6f0ec; border-radius: 50%; display: flex; align-items: center; justify-content: center; }

/* Blockquote rendered as a callout (uses the editor's existing Quote button) */
.cnp-seo-text blockquote { margin: 0 0 22px; padding: 16px 18px; background: #eaf5f1; border-left: 4px solid #2a7a6c; border-radius: 0 10px 10px 0; font-style: normal; color: #1d4a40; }
.cnp-seo-text blockquote p:last-child { margin-bottom: 0; }

/* Tables rendered as a clean facts table (uses the editor's existing Table button) */
.cnp-seo-text table { border-collapse: collapse; width: 100%; margin: 0 0 22px; font-size: 15px; background: #fff; border-radius: 10px; overflow: hidden; border: 1px solid #e6e6e2; }
.cnp-seo-text th, .cnp-seo-text td { padding: 11px 14px; text-align: left; border-bottom: 1px solid #ececea; }
.cnp-seo-text tr:last-child td, .cnp-seo-text tr:last-child th { border-bottom: 0; }
.cnp-seo-text thead th, .cnp-seo-text figure.table th { background: #f3f7f5; color: #15302b; font-weight: 700; }

/* Rules block styled as a card */
.cnp-rules-box { background: #fff; border: 1px solid #e6e6e2; border-radius: 12px; padding: 20px 24px; }

/* Shortcode blocks */
.cnp-callout { margin: 0 0 22px; padding: 16px 18px; border-left: 4px solid; border-radius: 0 10px 10px 0; font-size: 15px; line-height: 1.65; }
.cnp-callout > :last-child { margin-bottom: 0; }
.cnp-callout--tip  { background: #eaf5f1; border-color: #2a7a6c; color: #1d4a40; }
.cnp-callout--note { background: #eef4fb; border-color: #2f6db0; color: #1c466f; }
.cnp-callout--warn { background: #fdf4e3; border-color: #d99323; color: #7a5310; }

.cnp-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 0 0 24px; }
.cnp-fact { background: #fff; border: 1px solid #e6e6e2; border-radius: 12px; padding: 15px 16px; }
.cnp-fact__label { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: #8a8f8b; font-weight: 700; margin-bottom: 4px; }
.cnp-fact__value { font-size: 15px; color: #15302b; font-weight: 600; }

/* Compact mobile search bar inside cnp-search-wrap */
.cnp-mobilebar { margin-top: 16px; height: auto !important; display: block; }
.cnp-mobilebar .searchmbl { height: auto; padding: 10px 14px; width: 100%; box-sizing: border-box; display: flex; align-items: center; gap: 10px; }

/* Mobile search popup — full-screen overlay on country new page.
   Must use div#mobilesearchpop to beat the global rule's specificity. */
div#mobilesearchpop {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  margin-left: 0 !important;
  z-index: 99999 !important;
  background: #fff !important;
  overflow-y: auto !important;
  padding: 20px 16px !important;
  box-sizing: border-box !important;
}

/* ── Mobile overrides ────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* Typography */
  .cnp-h1 { font-size: 20px; }
  .cnp-section-h2 { font-size: 18px; }
  .cnp-section-h3 { font-size: 15px; }
  .excitingsec .blackhead,
  .categorysec .blackhead { font-size: 18px; }

  /* Reduce vertical breathing room */
  .cnp-search-wrap { padding: 20px 0 28px; }
  .cnp-section, .cnp-section-alt { padding: 24px 0; }
  .cnp-section-seo { padding: 24px 0; }
  .cnp-listing-header { margin-top: 46px; padding-top: 10px; }
  .cnp-showing-count { display: none; }
nav.navbar.navbar-expand-lg.navbar-light{
    padding-bottom: 22px;
}
  /* Search band: remove teal background on mobile (search bar straddles header) */
  .cnp-searchband { background: transparent !important; padding: 0; }
  .cnp-mobilebar-wrap { padding-top: 8px; margin-bottom: -36px;position: absolute; }
  .cnp-mobilebar { height: auto !important; margin-top: -24px; }

  /* Charter card CTA full width on mobile */
  .cnp-charter-footer { flex-wrap: wrap; gap: 10px; }
  .cnp-btn-avail { width: 100%; text-align: center; box-sizing: border-box; }

a.sortfilter {
    display: block;
    width: 100%;
}
}