/* --- BASE --- */
body {
  font-family: 'Segoe UI', Arial, sans-serif;
  color: #212529;
  margin: 0;
  padding: 0;
  min-height: 100vh;
  background:
  linear-gradient(to bottom, rgba(255,255,255,1.0), rgba(255,255,255,0.9)),
  url('../images/water_background.jpg') center center / cover no-repeat;
  background-repeat: no-repeat;
  background-attachment: fixed;
}



/* --- HANDWRITTEN HERO HIGHLIGHT --- */
.hero-section .highlight {
  font-family: 'Caveat', cursive;
  font-size: 1.3em;
  letter-spacing: 1.5px;
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: initial;
  font-family: 'Caveat', cursive;
  font-size: 1.3em;
  letter-spacing: 1.5px;
  background: none;
  color: #fff;
  text-shadow: 0 4px 26px #08394e, 0 2px 6px #073053;
  position: relative;
  display: inline-block;
}
.hero-section .highlight::after {
  display: none; /* Remove the blue underline squiggle for this hero */
  position: relative;
  display: inline-block;
}
.hero-section .highlight::after {
  content: '';
  display: none;
  position: absolute;
  left: -0.2em;
  bottom: -0.22em;
  width: 105%;
  height: 22px;
  background: url("data:image/svg+xml;utf8,<svg width='100%' height='22' xmlns='http://www.w3.org/2000/svg'><path d='M3 15 Q30 25 170 12 Q260 6 320 16' stroke='%23fff' stroke-width='4' fill='none' stroke-linecap='round'/></svg>") no-repeat left bottom;
  background-size: 100% 22px;
  pointer-events: none;
  z-index: 1;
  opacity: 0.85;
}

/* --- HEADER --- */

header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #fff;
  color: #134664;
  border-radius: 0 0 20px 20px;
  box-shadow: 0 2px 24px 0 #c2e2ef66;
  margin: 0 0 0em 0;
  width: 100%;
  min-width: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center; /* changed from space-between to center */
  min-height: 72px;
}

.faros-logo {
  display: none; /* Hide logo for a truly centered nav; or use margin if you want logo */
}

nav {
  display: flex;
  gap: 2.2em;
  align-items: center;
  justify-content: center;
  flex: 1 1 0;
  margin: 0;
  width: 100%;
}
nav a {
  color: #24678e;
  background: none;
  padding: 0.45em 0.7em;
  border-radius: 0;
  text-decoration: none;
  font-weight: 600;
  font-size: 1.09em;
  letter-spacing: 0.25px;
  box-shadow: none;
  margin: 0 0.11em;
  border-bottom: 2.5px solid transparent;
  transition: color 0.17s, border-bottom 0.19s;
  position: relative;
}
nav a.active,
nav a:hover {
  color: #2c9ad8;
  border-bottom: 2.5px solid #2c9ad8;
}
@media (max-width: 700px) {
  header {
    flex-direction: column;
    min-height: 52px;
    margin: 0 0 1.2em 0;
    padding: 0.3em 0.4em;
    border-radius: 0 0 12px 12px;
  }
  nav { gap: 0.7em; }
  nav a { padding: 0.64em 0.3em; font-size: 1em; }
}


/* --- FOOTER --- */

footer {
  background: #fff;
  color: #24678e;
  box-shadow: 0 -1px 16px #d1e7ef3a;
  border-radius: 16px 16px 0 0;
  margin: 6em auto 0 auto;
  padding: 2em 0 1.2em 0;
  position: relative;
  text-align: center;
  max-width: 100vw;
  font-size: 1.09em;
  font-family: inherit;
}
footer::before {
  display: none;
}
footer p {
  margin: 0;
  font-family: inherit;
  font-size: 1.09em;
  color: #1787c8;
  letter-spacing: 0.5px;
}


/* --- HERO SECTION --- */
.hero-section {
  position: relative;
  min-height: 340px;
  background: linear-gradient(120deg, #47b0d7 30%, #d3f8fd 90%);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: left;
  padding: 3.5em 1.4em 2.2em 1.4em;
  border-bottom-left-radius: 44px;
  border-bottom-right-radius: 44px;
  overflow: hidden;
  box-shadow: 0 5px 38px #1c6d8d22;
  margin-bottom: 0;
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
background: 
  linear-gradient(0deg,rgba(0,36,54,0.47) 0%,rgba(12,64,96,0.28) 100%),
  url('../images/img1.jpg') center/cover no-repeat;
  opacity: 1;
  filter: brightness(0.94) blur(0.2px); /* tweak as desired */
  transition: background 0.18s;
}


.hero-content {
  position: relative;
  z-index: 2;
  max-width: 650px;
  margin: 0 auto;
  padding: 1em 0;
}
.hero-section h1 {
  font-size: 2.8em;
  color: #044a68;
  font-weight: 800;
  margin: 0 0 0.25em 0;
  letter-spacing: -1px;
  line-height: 1.12;
}

/* --- INTRO GALLERY / FEATURE BLOCKS --- */
.intro-gallery {
  margin: 0 auto 2em auto;
  max-width: 1100px;
  padding: 0 1.2em;
}
.intro-block {
  display: flex;
  align-items: center;
  gap: 2.6em;
  background: #fff;
  border-radius: 26px;
  margin: 1.2em 0;
  box-shadow: 0 2px 14px #3db7c312;
  padding: 2.5em 2.2em;
  position: relative;
  border: 2.5px dashed #b3f0e5;
}
.intro-block img {
  width: 250px;
  max-width: 100%;
  border-radius: 18px;
  box-shadow: 0 2px 8px #0699a12a;
}
.intro-block.left-img img { order: 1; }
.intro-block.left-img > div { order: 2; }
.intro-block.right-img { flex-direction: row-reverse; }
.intro-block.center-img {
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.1em;
  background: linear-gradient(95deg,#cff3fe 0%,#f8fffd 90%);
}
.intro-block h2 {
  font-size: 2em;
  margin: 0 0 0.3em 0;
  color: #038690;
  font-weight: 700;
  font-family: 'Caveat', cursive, Arial, sans-serif;
  letter-spacing: 1.1px;
}
.intro-block p {
  font-size: 1.15em;
  color: #126169;
  margin: 0.2em 0 0.1em 0;
}

/* --- MAIN/YACHTS --- */
main {
  max-width: 1200px;
  margin: 2em auto 2em auto;
  padding: 0 1.2em;
}

#yacht-list {
  display: flex;
  flex-direction: column;
  gap: 0.3em;
  max-width: 1150px;
  width: 98vw;
  margin: 0 auto;
  padding: 0 1.2em;
}
.yacht-field {
  background: rgba(255,255,255,0.97);
  box-shadow: 0 4px 18px rgba(44, 86, 115, 0.16);
  border-radius: 33px;
  margin-bottom: 2em;
  display: flex;
  align-items: center;
  padding: 2em 2.4em;
  min-height: 380px;
  gap: 3em;
  flex-wrap: wrap;
  width: 100%;
  position: relative;
  opacity: 0;
  border: 2.2px solid #e8fafd;
  transform: translateY(32px);
  animation: yachtfade 0.8s ease-in-out forwards;
}
.yacht-field:nth-child(1) { animation-delay: 0.05s; }
.yacht-field:nth-child(2) { animation-delay: 0.14s; }
.yacht-field:nth-child(3) { animation-delay: 0.23s; }
.yacht-field:nth-child(4) { animation-delay: 0.32s; }
.yacht-field:nth-child(5) { animation-delay: 0.41s; }

@keyframes yachtfade {
  to { opacity: 1; transform: none; }
}

.yacht-image img {
  max-width: 480px;
  min-width: 240px;
  border-radius: 16px;
  box-shadow: 0 4px 18px 0 rgba(34, 54, 68, 0.12);
  display: block;
  transition: box-shadow 0.19s, transform 0.18s;
}
.yacht-image img:hover {
  box-shadow: 0 8px 32px 0 #57e6e0b8;
  transform: scale(1.04) rotate(-1deg);
}

.yacht-details {
  flex: 1;
}

.yacht-details h2 {
  margin-top: 0;
  font-size: 1.7em;
  margin-bottom: 0.2em;
  color: #026873;
  letter-spacing: 0.02em;
  font-family: 'Caveat', cursive, Arial, sans-serif;
}

.book-button {
  display: inline-block;
  background: linear-gradient(88deg,#00d894 0%, #07c6b4 100%);
  color: #fff;
  border: none;
  border-radius: 22px;
  padding: 0.95em 2.8em;
  font-size: 1.15em;
  cursor: pointer;
  margin-top: 1em;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 2px 14px #1eaea430;
  transition: background 0.15s, box-shadow 0.17s, transform 0.13s;
  position: relative;
}
.book-button[style*="pointer-events: none"] {
  opacity: 0.47 !important;
  filter: grayscale(60%) blur(0.5px);
  cursor: not-allowed !important;
  background: #c7dadb !important;
  color: #6b7c7e !important;
  box-shadow: none !important;
  transition: opacity 0.13s, background 0.13s, color 0.13s;
}
.book-button:hover {
  background: linear-gradient(90deg,#fd7657 0%, #00d8d4 100%);
  box-shadow: 0 7px 22px #57ebf780;
  transform: scale(1.11) rotate(-2deg);
  color: #fff;
  animation: bounce 0.32s cubic-bezier(.75,1.8,.65,1.2);
}
@keyframes bounce {
  0%   { transform: scale(1.04) rotate(-1deg);}
  60%  { transform: scale(1.17) rotate(-3deg);}
  100% { transform: scale(1.11) rotate(-2deg);}
}

.calendar-slot {
  min-width: 400px;
  margin-left: auto;
}

.calendar {
  background: #f7fbfe;
  padding: 1em;
  border-radius: 14px;
  box-shadow: 0 2px 16px rgba(34,54,68,0.08);
  max-width: 400px;
  transition: box-shadow 0.2s;
}
.calendar:hover {
  box-shadow: 0 8px 34px #54e1e08a;
}

.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 600;
  margin-bottom: 0.7em;
  color: #03607d;
}
.calendar-title {
  flex: 1;
  text-align: center;
  font-size: 1.09em;
  letter-spacing: 0.03em;
}
.nav-btn {
  background: #aee6e6;
  border: none;
  border-radius: 6px;
  width: 2em;
  height: 2em;
  font-weight: bold;
  font-size: 1.1em;
  cursor: pointer;
  margin: 0 0.2em;
  color: #06777b;
  transition: background 0.12s, color 0.13s;
}
.nav-btn:hover {
  background: #53ffc1;
  color: #065c59;
}
.calendar-days {
  display: flex;
}
.calendar-day {
  width: 3.2em;
  height: 2.7em;
  line-height: 2em;
  margin: 0.07em;
  text-align: center;
  border-radius: 5px;
  cursor: pointer;
  background: #d4fbec;
  font-size: 1em;
  font-weight: 500;
  user-select: none;
  transition: background 0.13s, color 0.13s, transform 0.14s;
}
.calendar-day.empty {
  background: none !important;
  cursor: default;
  color: #b2b2b2;
}
.calendar-day.free {
  background: #c2f0c2;
  color: #176020;
  box-shadow: 0 0px 0px #0000;
}
.calendar-day.booked {
  background: #fd7657 !important;
  color: #fff !important;
  pointer-events: none;
  opacity: 0.87;
  box-shadow: 0 2px 8px #fd765739;
}
.calendar-day.past {
  background: #e7e8ea !important;
  color: #aaa !important;
  pointer-events: none;
}
.calendar-day.selected,
.calendar-day.between {
  background: linear-gradient(89deg, #20a894 0%, #72fae0 100%) !important;
  color: #fff !important;
  font-weight: bold;
  border: 0px solid #09afba;
  box-shadow: 0 2px 7px #00c7ff40;
  z-index: 1;
  transform: scale(1.05);
}
.calendar-day:hover {
  filter: brightness(0.97);
  transform: scale(1.08);
  z-index: 1;
}

.legend {
  margin-top: 0.8em;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.legend-dot {
  display: inline-block;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 4px;
  margin-left: 12px;
  border: 1px solid #bbb;
  box-sizing: border-box;
  transition: border 0.18s, background 0.18s;
}
.legend-dot.free {
  background: #c2f0c2;
  border-color: #72cc72;
}
.legend-dot.booked {
  background: #fd7657;
  border-color: #b53427;
}
.status {
  margin: 1em 0 0 0;
  color: #14821b;
  font-weight: 600;
}
.booking-section {
  max-width: 480px;
  margin: 2em auto;
  background: #f8fffd;
  border-radius: 14px;
  box-shadow: 0 2px 18px rgba(44,86,115,0.08);
  padding: 2em;
  animation: fadein 1.05s;
}
@keyframes fadein {
  from { opacity: 0; transform: scale(0.96);}
  to   { opacity: 1; transform: none;}
}
.booking-form label {
  display: block;
  margin-bottom: 1em;
  font-size: 1.11em;
  font-weight: 500;
  color: #03607d;
}
.booking-form input[type="text"],
.booking-form input[type="email"] {
  width: 100%;
  padding: 0.72em;
  margin-top: 0.4em;
  border-radius: 5px;
  border: 1.5px solid #ace9e7;
  font-size: 1em;
  box-sizing: border-box;
  background: #eef8fa;
  transition: border 0.14s;
}
.booking-form input[type="text"]:focus,
.booking-form input[type="email"]:focus {
  border-color: #05c3c7;
}
.booking-form button {
  margin-top: 1em;
  background: linear-gradient(88deg,#00d894 0%, #07c6b4 100%);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 0.9em 2em;
  font-size: 1em;
  cursor: pointer;
  font-weight: 600;
  transition: background 0.15s, box-shadow 0.14s;
  box-shadow: 0 2px 8px #1eaea43a;
}
.booking-form button:hover {
  background: linear-gradient(90deg,#fd7657 0%, #00d8d4 100%);
  box-shadow: 0 5px 16px #37e3e0a7;
}

/* --- Booking Overview (overview.html) --- */
.faros-overview main {
  max-width: 820px;
  margin: 2.3em auto 2em auto;
  padding: 0 1em;
}

.step-indicator {
  display: flex;
  align-items: center;
  gap: 1.1em;
  margin: 1.5em 0 1.5em 0;
  background: linear-gradient(98deg, #e5fdff 20%, #b9fff3 90%);
  padding: 0.8em 1.8em;
  border-radius: 16px;
  box-shadow: 0 2px 16px #2ec6c43a;
  font-size: 1.18em;
  letter-spacing: 0.2px;
}
.step-num {
  font-family: 'Caveat', cursive;
  color: #0ea392;
  font-size: 2.3em;
  font-weight: bold;
  margin-right: 0.1em;
}
.step-desc {
  color: #016e70;
  font-size: 1.25em;
  font-weight: 700;
  margin-right: 1em;
}
.step-extra {
  color: #5bb7c7;
  font-size: 1em;
  font-family: inherit;
  margin-left: auto;
  font-weight: 500;
}

.booking-summary-card {
  display: flex;
  gap: 1.5em;
  align-items: center;
  background: #f8fffc;
  border-radius: 18px;
  box-shadow: 0 2px 16px #22c1b02a;
  padding: 2.2em 2.4em;
  margin-bottom: 2.2em;
}
.summary-img img {
  width: 170px;
  height: 120px;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 3px 10px #3fd3d12b;
  cursor: pointer;
}
.summary-content {
  flex: 1;
  min-width: 0;
}
.summary-title {
  font-family: 'Caveat', cursive;
  font-size: 2em;
  margin-bottom: 0.2em;
  color: #026873;
  line-height: 1.12;
}
.summary-detail {
  font-size: 1.05em;
  margin-bottom: 0.24em;
  color: #18747b;
}
.icon {
  font-size: 1.18em;
  margin-right: 0.25em;
  vertical-align: middle;
}

/* --- Modal for gallery --- */
.modal-gallery {
  position: fixed; z-index: 9000; left: 0; top: 0; width: 100vw; height: 100vh;
  background: rgba(0,0,0,0.68); display: flex; align-items: center; justify-content: center;
}
.modal-content {
  position: relative; background: #fff; padding: 0.6em 1.3em 1.3em 1.3em;
  border-radius: 12px; box-shadow: 0 2px 30px rgba(34,54,68,0.2);
  display: flex; flex-direction: column; align-items: center;
}
.modal-content img {
  max-width: 75vw; max-height: 68vh; border-radius: 8px; margin: 0.8em 0;
}
.close-modal {
  position: absolute; top: 0.5em; right: 1em; font-size: 2em;
  color: #444; cursor: pointer; font-weight: bold; z-index: 10;
}
.modal-controls { display: flex; gap: 2em; justify-content: center; }
.modal-controls button {
  background: #eee; border: none; border-radius: 50%; font-size: 1.6em;
  padding: 0.15em 0.42em; cursor: pointer; margin: 0 0.5em; color: #333;
  box-shadow: 0 2px 8px rgba(34,54,68,0.08);
}
.modal-controls button:hover {
  background: #c2f0c2; color: #009e60;
}

/* --- Addons area --- */
#addons-area {
  margin-bottom: 2.2em;
}
.addon-title {
  font-family: 'Caveat', cursive;
  color: #008e80;
  font-size: 1.35em;
  font-weight: 700;
  margin-bottom: 0.8em;
  display: inline-block;
  padding: 0.30em 1.2em;
  background: linear-gradient(91deg, #e2fdff 10%, #e5fff3 90%);
  border-radius: 1.5em;
  box-shadow: 0 2px 8px #23e2c51e;
  border: 2px solid #8de9e6;
}

.addon-list-flex {
  display: flex;
  gap: 1.2em;
  flex-wrap: wrap;
}
.addon-pill {
  background: linear-gradient(95deg,#e4fcf8 0%,#e8fdff 90%);
  border: 2px solid #a0e5df;
  border-radius: 1.4em;
  box-shadow: 0 2px 10px #3dc6b018;
  padding: 1.1em 1.6em 0.7em 1.6em;
  display: flex;
  flex-direction: column;
  min-width: 180px;
  position: relative;
  font-size: 1.06em;
  cursor: pointer;
  transition: box-shadow 0.14s, border 0.14s, background 0.17s;
}

.addon-pill:hover, .addon-pill:focus-within {
  border-color: #12b7ad;         /* ONLY color, not width */
  background: #e1fcf7;
  box-shadow: 0 5px 18px #1fd1c530;
}

/* Highlight entire pill if checked */
.addon-checkbox:checked ~ .addon-label-main,
.addon-checkbox:checked ~ .addon-label-desc,
.addon-checkbox:checked ~ .addon-price {
  color: #01846c;
}
.addon-checkbox:checked ~ .addon-label-main {
  font-weight: 700;
}

.addon-pill:has(.addon-checkbox:checked) {
  background: linear-gradient(96deg, #a7ffeb 0%, #e3fff9 100%);
  border-color: #22d0d3;         /* ONLY color, not width */
  box-shadow: 0 6px 22px #8ae9e98a;
}
.addon-checkbox {
  /* Make checkbox invisible but still accessible */
  width: 1.2em; height: 1.2em;
  opacity: 0; margin-right: -1.2em; margin-left: 0;
  pointer-events: none;
  position: absolute;
  left: 12px; top: 20px;
}

/* Add a custom checkmark indicator in pill when selected */
.addon-pill:has(.addon-checkbox:checked)::after {
  content: '✓';
  position: absolute;
  top: 45px; left: 25px;
  font-size: 1.5em;
  color: #04aa88;
  background: none;
  z-index: 2;
  font-family: Arial, sans-serif;
}

/* Prevent label text from shifting due to checkmark overlay */
.addon-label-main {
  color: #066879;
  font-weight: 700;
  font-size: 1.1em;
}

.addon-label-desc,
.addon-price {
  margin-left: 1.9em;
}

.overview-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.7em;
  margin-top: 2.1em;
}
.back-btn {
  background: linear-gradient(90deg,#d6f7ff 0%, #b4fffa 100%);
  color: #0d556b;
  border: 2.5px solid #22d0d3;
  border-radius: 1.5em;
  padding: 0.8em 2.4em;
  font-size: 1.13em;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 2px 8px #8ae9e98a;
  transition: border 0.14s, color 0.16s, background 0.14s, box-shadow 0.18s;
  display: flex;
  align-items: center;
  gap: 0.7em;
}
.back-btn:hover, .back-btn:focus {
  background: linear-gradient(90deg,#befcff 0%, #a3f2e7 100%);
  border: 2.5px solid #189ca7;
  color: #0a4347;
  box-shadow: 0 6px 22px #9befe0ba;
}
.back-btn::before {
  content: "←";
  display: inline-block;
  margin-right: 0.45em;
  font-size: 1.3em;
  font-weight: bold;
}
.continue-btn {
  background: linear-gradient(88deg,#00d894 0%, #07c6b4 100%);
  color: #fff;
  border: none;
  border-radius: 2em;
  padding: 1em 2.8em;
  font-size: 1.14em;
  font-weight: 700;
  box-shadow: 0 2px 14px #1eaea430;
  cursor: pointer;
  transition: background 0.13s, box-shadow 0.15s, transform 0.13s;
}
.continue-btn:hover {
  background: linear-gradient(90deg,#fd7657 0%, #00d8d4 100%);
  box-shadow: 0 7px 22px #57ebf780;
  transform: scale(1.09) rotate(-2deg);
  color: #fff;
}
.summary-error {
  background: #fee7e6;
  color: #ae191a;
  border-radius: 9px;
  padding: 2em 2em;
  margin: 2.5em 0 2.2em 0;
  font-size: 1.18em;
  text-align: center;
  box-shadow: 0 2px 12px #fba9a931;
}

@media (max-width: 800px) {
  .yacht-field, .intro-block {
    flex-direction: column;
    gap: 1em;
    padding: 1.4em 1em;
    text-align: center;
    align-items: flex-start;
  }
  .yacht-field {
    padding: 1.5em 0.8em;
  }
  .calendar-slot {
    min-width: 100vw;
    max-width: 100vw;
    margin-left: 0;
    margin-top: 1em;
    padding: 0;
  }
  .intro-block img { width: 95vw; }
  .hero-section { padding: 2em 0.4em; min-height: 230px;}
}
@media (max-width: 700px) {
  .booking-summary-card { flex-direction: column; padding: 1.1em 0.4em;}
  .summary-img img { width: 95vw; height: 36vw; min-height: 100px;}
  .gallery-thumb-bar { margin-top: 0.4em; }
  .overview-actions { flex-direction: column; gap: 1.3em;}
  .addon-list-flex { gap: 0.55em; }
  .addon-pill { min-width: 99vw; }
}
@media (max-width: 550px) {
  .calendar, .calendar-slot { min-width: 100vw; max-width: 100vw; padding: 0;}
  .intro-block, .yacht-field, main { padding: 0.7em 0.15em !important; }
  .intro-block img { width: 98vw; }
}
/* Dropdown nav styles */
.dropdown {
  position: relative;
  display: inline-block;
}
.dropdown-content {
  display: none;
  position: absolute;
  left: 0;
  top: 145%;
  min-width: 210px;
  background: #fff;
  box-shadow: 0 2px 22px #15808025;
  border-radius: 18px;
  z-index: 10;
  padding: 0.6em 0.3em;
}
.dropdown-content a {
  color: #22888b;
  padding: 0.73em 1.2em;
  text-decoration: none;
  display: block;
  border-radius: 10px;
  font-weight: 600;
  font-size: 1.09em;
  transition: background 0.14s, color 0.14s;
}
.dropdown-content a:hover {
  background: #e8fcf6;
}
.dropdown:hover .dropdown-content,
.dropdown:focus-within .dropdown-content {
  display: block;
}  /* <-- THIS is the missing bracket! */

.yacht-field {
  scroll-margin-top: 90px; /* Now this will work! */
}







.services-title {
  text-align: center;
  font-size: 2.8em;
  font-family: 'Caveat', cursive;
  color: #02ab99;
  margin: 1.7em 0 1.2em 0;
  letter-spacing: 1.2px;
}

.service-pill {
  display: flex;
  align-items: center;
  background: #f8fffd;
  border-radius: 22px;
  box-shadow: 0 4px 32px #13b8bb27;
  margin: 2em auto;
  max-width: 830px;
  padding: 1.7em 2.3em;
  gap: 2em;
  transition: box-shadow 0.2s;
}
.service-pill:hover {
  box-shadow: 0 8px 40px #13b8bb33;
}
.service-img img {
  width: 140px;
  height: 140px;
  object-fit: cover;
  border-radius: 18px;
  box-shadow: 0 2px 12px #1fc5aa22;
  background: #e9fcf7;
}
.service-info h2 {
  font-size: 2em;
  margin-bottom: 0.15em;
  color: #12ad91;
  font-family: 'Caveat', cursive;
}
.service-info p {
  margin-bottom: 0.8em;
  color: #17617b;
  font-size: 1.13em;
  font-weight: 400;
}
.service-btn {
  background: #02ab99;
  color: #fff;
  border: none;
  border-radius: 13px;
  padding: 0.7em 1.7em;
  font-weight: 600;
  font-size: 1.05em;
  text-decoration: none;
  transition: background 0.18s;
  box-shadow: 0 2px 10px #03f3dc28;
  cursor: pointer;
}
.service-btn:hover {
  background: #159b84;
}
@media (max-width: 800px) {
  .service-pill { flex-direction: column; gap: 1.1em; padding: 1.4em 0.7em;}
  .service-img img { width: 90vw; max-width: 250px; height: 20vw; min-height: 96px;}
  .services-title { font-size: 2em; }
}









.service-preview {
  flex: 1 1 160px;
  padding-left: 2em;
  min-width: 130px;
  display: flex;
  align-items: center;
}

.service-preview ul {
  list-style-type: disc;
  margin: 0;
  padding-left: 1em;
  color: #0e868a;
  font-size: 2.02em;
  line-height: 1.5;
}
.service-preview li {
  margin-bottom: 0em;
  font-size: 1.01em;
  border-left: 2.5px solid #a3e4d7;
  padding-left: 0.7em;
}
@media (max-width: 900px) {
  .service-preview {
    display: none; /* Hide preview list on mobile for simplicity */
  }
}











.nav-pill-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: linear-gradient(90deg, #e7fdff 30%, #c3fbe5 100%);
  border-radius: 19px;
  box-shadow: 0 2px 18px #14e7f325;
  padding: 1.4em 1.2em 1em 1.2em;
  margin: 0 0.1em;
  font-size: 1.18em;
  font-weight: 600;
  color: #1688a1;
  text-decoration: none;
  min-width: 135px;
  min-height: 90px;
  transition: box-shadow 0.13s, background 0.18s, transform 0.14s, color 0.15s;
  border: 2.2px solid #c4f5e8;
  position: relative;
  cursor: pointer;
}
.nav-pill-link:hover, .nav-pill-link:focus {
  background: linear-gradient(90deg, #81f0ec 0%, #b7ffd4 100%);
  box-shadow: 0 6px 30px #20b5c980;
  color: #049baa;
  transform: translateY(-5px) scale(1.045);
  z-index: 2;
  outline: none;
}
.nav-pill-icon {
  font-size: 2.1em;
  margin-bottom: 0.37em;
  line-height: 1;
  text-shadow: 0 1px 8px #0ff4fc12;
  display: block;
}
.nav-pill-title {
  font-family: 'Caveat', cursive, Arial, sans-serif;
  font-size: 1.09em;
  font-weight: 700;
  letter-spacing: 0.7px;
  color: inherit;
}

@media (max-width: 900px) {
  .service-pill { flex-wrap: wrap; }
  .nav-pill-link {
    min-width: 130px;
    min-height: 74px;
    font-size: 1em;
    padding: 1em 0.7em 0.8em 0.7em;
  }
}
@media (max-width: 700px) {
  .service-pill {
    flex-direction: column;
    gap: 0.7em;
    align-items: stretch;
  }
  .nav-pill-link {
    width: 95vw;
    min-width: 0;
    margin: 0 auto;
    font-size: 1em;
    text-align: center;
  }
}




.about-info-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 2.2em 2em;
  justify-content: center;
  max-width: 1140px;
  margin: 3.1em auto;
}
.about-pill {
  flex: 1 1 230px;
  min-width: 255px;
  max-width: 260px;
  min-height: 255px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  justify-content: flex-start;
  padding: 2em 1.2em 1.2em 1.2em;
}
.about-pill-icon {
  font-size: 2.3em;
  margin-bottom: 0.5em;
  line-height: 1;
  display: block;
}
.about-pill h3 {
  margin: 0 0 0.55em 0;
  font-size: 1.13em;
  font-weight: 700;
}
.about-pill p {
  font-size: 1.05em;
  color: #17647b;
  margin: 0;
  line-height: 1.5;
  /* Remove forced height and flex: */
}

@media (max-width: 900px) {
  .about-info-pills { gap: 1em 0.6em; }
  .about-pill { min-width: 170px; max-width: 99vw; min-height: 220px; padding: 1.4em 0.4em 1em 0.4em;}
}
@media (max-width: 700px) {
  .about-info-pills { flex-direction: column; gap: 1em; }
  .about-pill { min-width: 0; width: 97vw; max-width: 99vw; min-height: 150px; }
}








.about-main-field {
  background: #f8fffd;
  border-radius: 26px;
  box-shadow: 0 4px 32px #13b8bb27;
  padding: 2.3em 2.8em 2em 2.8em;
  max-width: 700px;
  margin: 0.4em auto 0.2em auto;
  text-align: center;
  position: relative;
  z-index: 2;
  font-size: 1.37em;
  color: #13617b;
  font-weight: 400;
  line-height: 1.64;
}
.about-main-field h2 {
  font-size: 2.1em;
  color: #02ab99;
  font-family: 'Caveat', cursive;
  margin-bottom: 0.5em;
}

