@charset "utf-8";

/* =========================================================
   DIVER ON TOUR – SCHNORCHELTOUREN BUCHUNG
   Datei: /assets/css/schnorchelturen-in-hurghada.css
========================================================= */

*{
  box-sizing:border-box;
}

html,
body{
  margin:0;
  padding:0;
  max-width:100%;
  overflow-x:hidden;
}

body{
  font-family:Arial,Helvetica,sans-serif;
  background:#ffffff;
  color:#163047;
}

img{
  display:block;
  max-width:100%;
  height:auto;
}

.dot-section{
  padding:56px 0;
}

.dot-container{
  width:min(1200px, calc(100% - 32px));
  margin:0 auto;
}

.dot-section-title{
  margin:0 0 14px;
  font-size:34px;
  line-height:1.2;
  text-align:center;
  color:#0e3a5a;
}

.dot-section-intro{
  max-width:920px;
  margin:0 auto 32px;
  font-size:17px;
  line-height:1.8;
  text-align:center;
  color:#4f6477;
}

/* =========================================================
   HIGHLIGHTS
========================================================= */

.dot-highlights{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.dot-highlight-card{
  background:#ffffff;
  border:1px solid #d9e7f0;
  border-radius:20px;
  padding:24px;
  box-shadow:0 10px 26px rgba(0,0,0,0.05);
}

.dot-highlight-card h2,
.dot-highlight-card h3{
  margin:0 0 10px;
  font-size:22px;
  line-height:1.3;
  color:#0e3a5a;
}

.dot-highlight-card p{
  margin:0;
  font-size:15px;
  line-height:1.75;
  color:#4e6578;
}

/* =========================================================
   BUCHUNGSBEREICH
========================================================= */

.dot-snorkel-booking{
  background:#ffffff;
  border:1px solid #c9d9e5;
  border-radius:22px;
  box-shadow:0 10px 28px rgba(0,0,0,0.06);
  padding:28px;
}

.dot-snorkel-form-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 340px;
  gap:24px;
  align-items:start;
}

.dot-snorkel-form-main{
  min-width:0;
}

.dot-snorkel-form-main--details{
  grid-column:1 / 2;
}

.dot-snorkel-summary-panel{
  position:sticky;
  top:20px;
  align-self:start;
}

/* =========================================================
   ÜBERSCHRIFTEN IM BUCHUNGSBEREICH
========================================================= */

.dot-snorkel-booking__title{
  margin:0 0 12px;
  font-size:24px;
  line-height:1.3;
  color:#0e3a5a;
}

.dot-snorkel-booking__subtitle{
  margin:0 0 22px;
  font-size:15px;
  line-height:1.7;
  color:#597084;
}

/* =========================================================
   TOURENKARTEN
========================================================= */

.dot-snorkel-cards{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
  width:100%;
  margin-bottom:30px;
}

.dot-snorkel-card{
  position:relative;
  min-width:0;
}

.dot-snorkel-card--selectable{
  display:block;
  cursor:pointer;
}

.dot-snorkel-card__radio{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.dot-snorkel-card__inner{
  display:flex;
  flex-direction:column;
  height:100%;
  background:#ffffff;
  border:1px solid #c9d9e5;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 22px rgba(0,0,0,0.05);
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease, background-color .2s ease;
}

.dot-snorkel-card--selectable:hover .dot-snorkel-card__inner{
  border-color:#9fc2dd;
  box-shadow:0 10px 24px rgba(14,58,90,0.10);
}

.dot-snorkel-card__radio:checked + .dot-snorkel-card__inner{
  border-color:#7edc98;
  background:#f5fff8;
  box-shadow:0 0 0 4px rgba(126,220,152,0.20), 0 12px 26px rgba(126,220,152,0.24);
}

.dot-snorkel-card__image{
  width:100%;
  aspect-ratio:16 / 9;
  background:linear-gradient(135deg,#d9e9f3 0%, #eef5fa 100%);
  border-bottom:1px solid #d9e7f0;
  overflow:hidden;
}

.dot-snorkel-card__image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.dot-snorkel-card__title,
.dot-snorkel-card__text,
.dot-snorkel-card__price,
.dot-snorkel-card__qty{
  display:block;
  margin-left:18px;
  margin-right:18px;
}

.dot-snorkel-card__title{
  margin-top:18px;
  font-size:20px;
  line-height:1.35;
  font-weight:700;
  color:#0e3a5a;
}

.dot-snorkel-card__text{
  margin-top:12px;
  font-size:15px;
  line-height:1.75;
  color:#4e6578;
}

.dot-snorkel-card__text strong{
  display:block;
  margin-bottom:6px;
  color:#0e3a5a;
}

.dot-snorkel-card__price{
  margin-top:16px;
  padding:12px 14px;
  border-radius:14px;
  background:#0e3a5a;
  color:#ffffff;
  font-size:18px;
  line-height:1.4;
  font-weight:700;
  transition:background-color .2s ease;
}

.dot-snorkel-card__radio:checked + .dot-snorkel-card__inner .dot-snorkel-card__price{
  background:#167a3f;
}

.dot-snorkel-card__qty{
  margin-top:16px;
}

.dot-snorkel-card__qty:last-child{
  margin-bottom:18px;
}

.dot-snorkel-card__fieldlabel{
  display:block;
  margin-bottom:8px;
  font-size:14px;
  font-weight:700;
  color:#0e3a5a;
}

.dot-snorkel-card__qty select{
  width:100%;
  border:1px solid #b9cedd;
  border-radius:14px;
  padding:13px 14px;
  font-size:15px;
  color:#163047;
  background:#ffffff;
  outline:none;
  font-family:Arial,Helvetica,sans-serif;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.dot-snorkel-card__qty select:focus{
  border-color:#7faecc;
  box-shadow:0 0 0 4px rgba(127,174,204,0.20);
}

/* =========================================================
   TRANSFER
========================================================= */

.dot-snorkel-transfer-box{
  margin-bottom:30px;
  padding:18px;
  border-radius:18px;
  background:#f8fbfd;
  border:1px solid #d9e7f0;
}

.dot-snorkel-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  line-height:1.7;
  color:#35556b;
  cursor:pointer;
}

.dot-snorkel-check input{
  width:auto;
  margin-top:3px;
  flex:0 0 auto;
}

.dot-snorkel-transfer-box .dot-snorkel-field{
  margin-top:16px;
}

/* =========================================================
   FORMULARFELDER
========================================================= */

.dot-snorkel-form-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
  width:100%;
  margin-bottom:30px;
}

.dot-snorkel-field{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}

.dot-snorkel-field--full{
  grid-column:1 / -1;
}

.dot-snorkel-field label{
  font-size:14px;
  font-weight:700;
  color:#0e3a5a;
}

.dot-snorkel-field input,
.dot-snorkel-field select,
.dot-snorkel-field textarea{
  width:100%;
  border:1px solid #b9cedd;
  border-radius:14px;
  padding:13px 14px;
  font-size:15px;
  color:#163047;
  background:#ffffff;
  outline:none;
  font-family:Arial,Helvetica,sans-serif;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.dot-snorkel-field input:focus,
.dot-snorkel-field select:focus,
.dot-snorkel-field textarea:focus{
  border-color:#7faecc;
  box-shadow:0 0 0 4px rgba(127,174,204,0.20);
}

.dot-snorkel-checkbox-row{
  margin-top:8px;
}

.dot-snorkel-checkbox-row + .dot-snorkel-checkbox-row{
  margin-top:12px;
}

.dot-snorkel-button-row{
  margin-top:24px;
}

.dot-snorkel-button-row .dot-btn-primary{
  width:100%;
  justify-content:center;
}

/* =========================================================
   PREISRECHNER / ZUSAMMENFASSUNG
========================================================= */

.dot-snorkel-summary{
  background:#ffffff;
  border:1px solid #c9d9e5;
  border-radius:22px;
  box-shadow:0 10px 28px rgba(0,0,0,0.06);
  padding:22px;
}

.dot-snorkel-summary__row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding-bottom:12px;
  margin-bottom:12px;
  border-bottom:1px solid #e6eef3;
  font-size:15px;
  line-height:1.6;
  color:#35556b;
}

.dot-snorkel-summary__row strong{
  color:#0e3a5a;
  text-align:right;
}

.dot-snorkel-summary__total{
  margin-bottom:0;
  padding-bottom:0;
  border-bottom:none;
  font-size:18px;
}

.dot-snorkel-summary__total strong{
  font-size:28px;
}

/* =========================================================
   FAQ-KARTEN
========================================================= */

.dot-faq-section{
  padding-top:24px;
}

.dot-faq-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
  margin-top:32px;
}

.dot-faq-card{
  background:#ffffff;
  border:1px solid rgba(14,58,90,0.12);
  border-radius:18px;
  padding:24px;
  box-shadow:0 10px 30px rgba(14,58,90,0.08);
  height:100%;
}

.dot-faq-card h3{
  margin:0 0 12px;
  font-size:18px;
  line-height:1.4;
  color:#0e3a5a;
}

.dot-faq-card p{
  margin:0;
  line-height:1.7;
  color:#334155;
  font-size:15px;
}

/* =========================================================
   BUTTONS / LINKS
========================================================= */

.dot-btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  border-radius:999px;
  padding:15px 26px;
  background:#0e3a5a;
  color:#ffffff;
  font-size:16px;
  font-weight:700;
  text-decoration:none;
  cursor:pointer;
  font-family:Arial,Helvetica,sans-serif;
  transition:background-color .2s ease, transform .2s ease;
}

.dot-btn-primary:hover{
  background:#145a87;
  transform:translateY(-1px);
}

.dot-top-link{
  display:inline-block;
  margin-top:18px;
  color:#0e3a5a;
  text-decoration:none;
  font-weight:700;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width:1100px){
  .dot-snorkel-form-layout{
    grid-template-columns:1fr;
  }

  .dot-snorkel-form-main--details{
    grid-column:auto;
  }

  .dot-snorkel-summary-panel{
    position:static;
  }
}

@media (max-width:980px){
  .dot-highlights,
  .dot-snorkel-cards,
  .dot-snorkel-form-grid,
  .dot-faq-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:760px){
  .dot-section{
    padding:40px 0;
  }

  .dot-container{
    width:min(100%, calc(100% - 28px));
  }

  .dot-section-title{
    font-size:28px;
  }

  .dot-section-intro{
    font-size:16px;
    margin-bottom:24px;
  }

  .dot-highlight-card,
  .dot-snorkel-booking,
  .dot-snorkel-summary,
  .dot-faq-card{
    padding:20px 16px;
    border-radius:18px;
  }

  .dot-snorkel-booking__title{
    font-size:22px;
  }

  .dot-snorkel-card__title{
    font-size:18px;
    margin-left:16px;
    margin-right:16px;
  }

  .dot-snorkel-card__text,
  .dot-snorkel-card__price,
  .dot-snorkel-card__qty{
    margin-left:16px;
    margin-right:16px;
  }

  .dot-snorkel-card__price{
    font-size:17px;
  }

  .dot-snorkel-summary__row{
    flex-direction:column;
    align-items:flex-start;
  }

  .dot-snorkel-summary__row strong{
    text-align:left;
  }

  .dot-snorkel-summary__total strong{
    font-size:24px;
  }

  .dot-faq-grid{
    gap:18px;
    margin-top:24px;
  }

  .dot-faq-card h3{
    font-size:17px;
  }
}