html {
   scroll-behavior: smooth;
}

/* =========================================================
   BAZA
========================================================= */
.container {
   position: relative;
   z-index: 2;
}

/* =========================================================
   SLIDER GÓRA
========================================================= */
.caption-box {
   position: relative;
   min-height: 42vh;
   background-size: cover;
   background-position: center;
   background-repeat: no-repeat;
}

.caption-box::before {
   content: "";
   position: absolute;
   inset: 0;
   background: linear-gradient(to top, rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.15));
   z-index: 1;
}

/* =========================================================
   YACHT OWL
========================================================= */
.yachtowl {
   position: relative;
   padding-top: 40px;
   background-color: #eee;
}

.yachtowl::after {
   content: "";
   position: absolute;
   right: 0;
   bottom: 0;
   left: 0;
   width: 100%;
}

#customers-yachtowl .item {
   position: relative;
   margin-bottom: 80px;
   padding: 14px;
   text-align: center;
}

#customers-yachtowl .item img {
   width: 100%;
   height: 350px;
   object-fit: cover;
}

#customers-yachtowl .item a {
   display: block;
   overflow: hidden;
}

#customers-yachtowl .item a img {
   transition: transform 0.6s ease;
}

#customers-yachtowl .item a:hover img {
   transform: scale(1.1);
}

#customers-yachtowl .item a:hover h4 {
   text-decoration: underline;
}

#customers-yachtowl .item a:hover {
   text-decoration: none;
}

#customers-yachtowl .item-details {
   position: relative;
   min-height: 150px;
   padding: 24px;
   color: #333;
   text-align: left;
   background-color: #fff;
}

#customers-yachtowl .item-details span {
   float: right;
   margin-top: 0;
   padding-right: 10px;
   color: #c09551;
}

#customers-yachtowl .owl-page > span {
   background: #eee;
   border: 3px solid #444;
}

/* =========================================================
   TYTUŁY SEKCJI
========================================================= */
section .section-supertitle {
   position: relative;
   margin-top: 2%;
   color: #222;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   font-size: clamp(23px, 1.2rem, 34px);
   text-align: center;
   letter-spacing: 3px;
}

section .section-supertitle-border {
   display: block;
   width: 70px;
   height: 3px;
   margin: 12px auto 1%;
   background: #c9a46c;
}

h1 {
   position: relative;
   margin-top: 2%;
   color: #222;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   font-size: clamp(63px, 3.2rem, 84px);
   text-align: center;
   letter-spacing: 3px;
}

.nasze-jachty-class {
   color: #6b5b53;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   font-size: clamp(15px, 1rem, 18px);
   letter-spacing: 0.5px;
}

/* =========================================================
   O NAS / JEZIORO WIGRY / BRYZGIEL / SEKCJE ŁODZI
========================================================= */
.about-section {
   margin: 0 auto;
   padding: 70px 30px;
   text-align: left;
}

#o-nas .container-fluid,
#jezioro-wigry .container-fluid,
#bryzgiel .container-fluid,
#wigierski-park .container-fluid,
#tango780 .container-fluid,
#twister800n .container-fluid,
#omega .container-fluid,
#pasja .container-fluid,
#corvette600 .container-fluid {
   max-width: 980px;
   margin: 0 auto;
   padding-right: 30px;
   padding-left: 30px;
}

.about-list-container {
   max-width: 640px;
   margin: 0 auto;
   padding-right: 30px;
   padding-left: 30px;
}

.about-section h2 {
   display: block;
   margin: 0 0 24px;
   color: #2f2724;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   font-size: clamp(36px, 2rem, 46px);
   font-weight: 700;
   line-height: 1.08;
   text-align: center;
}

.about-section p {
   max-width: 900px;
   margin: 0 0 18px;
   color: #747b84;
   font-size: clamp(16px, 1.05rem, 19px);
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   line-height: 1.75;
}

.about-section p strong {
   display: block;
   margin: 30px 0 18px;
   color: #2f2724;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   font-size: clamp(20px, 2rem, 30px);
   
   font-weight: 700;
   line-height: 1.2;
   text-align: center;
}

.about-list {
   margin: 0 0 28px;
   padding: 0;
   list-style: none;
}

.about-list li {
   position: relative;
   margin-bottom: 12px;
   padding-left: 22px;
   color: #747b84;
   font-size: clamp(16px, 1.05rem, 19px);
   line-height: 1.7;
}

.about-list li::before {
   content: "";
   position: absolute;
   top: 14px;
   left: 0;
   width: 7px;
   height: 7px;
   background: #c9a46c;
}

.about-list-map-center,
.wigry-map-center,
.wigierski-park-map-center,
.bryzgiel-map-center {
   margin: 40px 0;
   text-align: center;
}

.about-list-map-center img,
.wigierski-park-map-center img {
   width: 100%;
   max-width: 220px;
   height: auto;
   border-radius: 6px;
}

.wigry-map-center img,
.bryzgiel-map-center img {
   width: 100%;
   max-width: 420px;
   height: auto;
   border-radius: 6px;
}

.wigry-flex {
   display: flex;
   align-items: center;
   gap: 40px;
}

.wigry-text {
   flex: 1;
}

/* =========================================================
   SZCZEGÓŁY ŁODZI
========================================================= */
.jacht-opis h2 {
   margin-bottom: 26px;
   color: #342b2b;
   font-size: clamp(1.4rem, 5vw, 3.3rem);
   font-weight: 800;
   line-height: 1.05;
   
}

.jacht-opis h3 {
   text-align: center;
}

.jacht-opis p {
   color: #7d858c;
   font-size: clamp(1rem, 1.5vw, 1.55rem);
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   line-height: 1.75;
}

.boat-plan {
   display: flex;
   justify-content: center;
   align-items: center;
   width: 100%;
   margin: 30px auto 40px;
   text-align: center;
}

.boat-plan img {
   display: block;
   max-width: 780px;
   width: 100%;
   height: auto;
   margin: 0 auto;
}

.jacht-opis ul {
   list-style: none;
}

.details-row {
   display: flex;
   justify-content: space-between;
   gap: 40px;
   width: 100%;
}

.details-col1 {
   width: 45%;
}

.details-col2 {
   width: 30%;
}

.equipment-items {
   margin-bottom: 30px;
   padding-left: 0;
   list-style: none;
   border-left: 1px solid #c09551;
}

.equipment-items li {
   margin-bottom: 10px;
   margin-left: 20px;
}

.technical-data {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   margin-bottom: 45px;
   margin-left: 0;
   padding-left: 20px;
   border-left: 1px solid #c09551;
}

.technical-data li {
   display: flex;
   justify-content: space-between;
   align-items: center;
   width: 100%;
   margin-bottom: 15px;
}

/* =========================================================
   CZARTER GALERIA
========================================================= */
.gallery-content {
   margin-top: 50px;
}

.gallery-title {
   margin-bottom: 15px;
   color: #1f1f1f;
   font-size: 28px;
   line-height: 1.3;
   text-align: center;
}

.gallery-intro {
   max-width: 900px;
   margin: 0 auto 35px;
   color: #444;
   font-size: 17px;
   line-height: 1.8;
   text-align: center;
}

.czarter-gallery {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
   gap: 24px;
   margin-top: 20px;
}

.czarter-gallery-item {
   margin: 0;
}

.czarter-gallery-item a {
   display: block;
   overflow: hidden;
   border-radius: 14px;
   background: #f5f5f5;
   box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
}

.czarter-gallery-item img {
   display: block;
   width: 100%;
   height: 260px;
   object-fit: cover;
   transition: transform 0.35s ease;
}

.czarter-gallery-item a:hover img,
.czarter-gallery-item a:focus img {
   transform: scale(1.05);
}

/* =========================================================
   PRZYCISK TOP
========================================================= */
#scrollTopBtn {
   position: fixed;
   right: 30px;
   bottom: 30px;
   z-index: 9999;
   display: none;
   width: 50px;
   height: 50px;
   border: none;
   border-radius: 50%;
   color: #fff;
   font-size: 22px;
   cursor: poPlayfair Display;
   background-color: #c9a46c;
   transition: all 0.3s ease;
}

#scrollTopBtn:hover {
   background-color: #a8844f;
   transform: translateY(-3px);
}

/* =========================================================
   PŁYWAJĄCY BOX CZARTERU
========================================================= */
#floatingCharterBox {
   position: fixed;
   right: 16px;
   bottom: 110px;
   z-index: 9998;
   width: 300px;
   max-width: calc(100vw - 32px);
   padding: 16px 18px;
   color: #f4f2ed;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   text-align: left;
   background: #1f2941;
   border-radius: 12px;
   box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
   transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
}

#floatingCharterBox.is-hidden {
   opacity: 0;
   visibility: hidden;
   transform: translateY(20px);
   pointer-events: none;
}

#floatingCharterBox h4 {
   margin: 0 0 16px;
   color: #fff;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   font-size: 28px;
   font-weight: 700;
   line-height: 1.1;
}

#floatingCharterBox .contact-item {
   display: flex;
   align-items: center;
   gap: 12px;
   margin: 0 0 12px;
   font-size: 17px;
   line-height: 1.35;
}

#floatingCharterBox .contact-item:last-child {
   margin-bottom: 0;
}

#floatingCharterBox .contact-item a {
   color: #fff;
   text-decoration: none;
   word-break: break-word;
}

#floatingCharterBox .contact-item a:hover {
   text-decoration: underline;
}

#floatingCharterBox .contact-item::before {
   content: "";
   display: inline-block;
   flex: 0 0 18px;
   width: 18px;
   height: 18px;
   background-color: #c09551;
}

#floatingCharterBox .email::before {
   -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4-8 5-8-5V6l8 5 8-5v2z'/%3E%3C/svg%3E") no-repeat center / contain;
   mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4-8 5-8-5V6l8 5 8-5v2z'/%3E%3C/svg%3E") no-repeat center / contain;
}

#floatingCharterBox .phone::before {
   -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.62 10.79a15.15 15.15 0 006.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") no-repeat center / contain;
   mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.62 10.79a15.15 15.15 0 006.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") no-repeat center / contain;
}

/* =========================================================
   FOOTER
========================================================= */
.kamena-footer {
   padding: 60px 20px 20px;
   color: #1f2d4f;
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
   background: #e5e4e2;
}

.kamena-footer__inner {
   display: grid;
   grid-template-columns: 140px 1.8fr 1.2fr;
   gap: 50px;
   max-width: 1200px;
   margin: 0 auto;
}

.kamena-footer__col--logo,
.kamena-footer__col--map {
   display: flex;
   align-items: center;
   justify-content: center;
}

.kamena-footer__logo {
   width: 110px;
   margin-top: 15px;
}

.kamena-footer__title {
   margin-bottom: 10px;
   font-size: 26px;
   text-align: left;
}

.kamena-footer__address {
   margin-bottom: 15px;
   color: #666;
}

.kamena-footer__map iframe {
   width: 400px;
   height: 180px;
   border: 0;
   border-radius: 10px;
}

.kamena-contact-card {
   margin-top: 20px;
   text-align: left;
}

.line {
   display: grid;
   grid-template-columns: 26px 130px 1fr;
   align-items: center;
   gap: 10px;
   margin: 10px 0;
   text-align: left;
}

.line::before {
   content: "";
   width: 20px;
   height: 20px;
   background-color: #c09551;
}

.label {
   min-width: 130px;
   font-weight: 700;
   text-align: left;
}

.line a,
.line span:last-child {
   justify-self: start;
   text-align: left;
}

.line a {
   color: #1f2d4f;
   text-decoration: none;
}

.line a:hover {
   text-decoration: underline;
}

.line.phone::before {
   -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.62 10.79a15.15 15.15 0 006.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") no-repeat center / contain;
   mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.62 10.79a15.15 15.15 0 006.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") no-repeat center / contain;
}

.line.email::before {
   -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4-8 5-8-5V6l8 5 8-5v2z'/%3E%3C/svg%3E") no-repeat center / contain;
   mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4-8 5-8-5V6l8 5 8-5v2z'/%3E%3C/svg%3E") no-repeat center / contain;
}

.line.address::before {
   -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5A2.5 2.5 0 1112 6a2.5 2.5 0 010 5.5z'/%3E%3C/svg%3E") no-repeat center / contain;
   mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5A2.5 2.5 0 1112 6a2.5 2.5 0 010 5.5z'/%3E%3C/svg%3E") no-repeat center / contain;
}

.line.facebook::before {
   -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 12a10 10 0 10-11.56 9.87v-6.99H7.9V12h2.54V9.8c0-2.5 1.5-3.88 3.77-3.88 1.09 0 2.23.19 2.23.19v2.45h-1.26c-1.24 0-1.62.77-1.62 1.56V12h2.76l-.44 2.88h-2.32v6.99A10 10 0 0022 12z'/%3E%3C/svg%3E") no-repeat center / contain;
   mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 12a10 10 0 10-11.56 9.87v-6.99H7.9V12h2.54V9.8c0-2.5 1.5-3.88 3.77-3.88 1.09 0 2.23.19 2.23.19v2.45h-1.26c-1.24 0-1.62.77-1.62 1.56V12h2.76l-.44 2.88h-2.32v6.99A10 10 0 0022 12z'/%3E%3C/svg%3E") no-repeat center / contain;
}

.kamena-footer__bottom {
   margin-top: 40px;
   padding-top: 15px;
   color: #777;
   text-align: center;
   border-top: 1px solid #ddd;
}

body {
   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}

.clean-link {
   color: inherit;
   text-decoration: none;
   font-weight: inherit;
   font-family: inherit;
}

.clean-link:hover {
   text-decoration: underline;
}

/* =========================================================
   RESPONSYWNOŚĆ
========================================================= */
@media (max-width: 900px) {
   .wigry-flex,
   .wigry-hero,
   .details-row {
      flex-direction: column;
   }

   .details-col1,
   .details-col2 {
      width: 100%;
   }

   #floatingCharterBox {
      right: 12px;
      bottom: 95px;
      width: 250px;
      max-width: calc(100vw - 24px);
      padding: 14px 16px;
      border-radius: 12px;
   }

   #floatingCharterBox h4 {
      display: none;
   }

   #floatingCharterBox .contact-item {
      gap: 10px;
      margin: 0 0 10px;
      font-size: 15px;
      line-height: 1.35;
   }

   #floatingCharterBox .contact-item:last-child {
      margin-bottom: 0;
   }

   #floatingCharterBox .contact-item::before {
      flex: 0 0 18px;
      width: 18px;
      height: 18px;
   }

   #floatingCharterBox .email {
      font-size: 14px;
   }

   .kamena-footer__inner {
      grid-template-columns: 1fr;
   }

   .czarter-gallery-item img {
      height: 220px;
   }
}

@media (max-width: 768px) {
   .about-section {
      padding: 50px 20px;
   }

   .about-section h2 {
      font-size: 36px;
   }

   .about-section p,
   .about-list li {
      font-size: 17px;
      line-height: 1.7;
   }

   .about-section p strong {
      font-size: 24px;
   }

   #o-nas .container-fluid,
   #jezioro-wigry .container-fluid,
   #bryzgiel .container-fluid,
   #wigierski-park .container-fluid,
   #tango780 .container-fluid,
   #twister800n .container-fluid,
   #omega .container-fluid,
   #pasja .container-fluid,
   #corvette600 .container-fluid {
      padding-right: 20px;
      padding-left: 20px;
   }

   .czarter-gallery {
      grid-template-columns: 1fr;
      gap: 20px;
   }

   .czarter-gallery-item img {
      height: auto;
   }
}

@media (max-width: 640px) {
   #floatingCharterBox {
      right: 10px;
      bottom: 95px;
      width: 220px;
      max-width: calc(100vw - 20px);
      padding: 10px 12px;
      border-radius: 10px;
   }

   #floatingCharterBox h4 {
      display: none;
   }

   #floatingCharterBox .contact-item {
      gap: 8px;
      margin-bottom: 6px;
      font-size: 13px;
   }

   #floatingCharterBox .contact-item::before {
      width: 14px;
      height: 14px;
      flex-basis: 14px;
   }

   #scrollTopBtn {
      right: 20px;
      bottom: 20px;
      width: 46px;
      height: 46px;
      font-size: 20px;
   }

   .line {
      grid-template-columns: 22px 110px 1fr;
      gap: 8px;
   }

   .kamena-footer__title {
      font-size: 22px;
   }

   .kamena-footer__logo {
      width: 95px;
   }
}