@charset "utf-8";

/* =========================================================
   DIVER ON TOUR – TAUCHSAFARI NORDTOUREN BUCHUNG
   Datei: /assets/css/tauchsafari-nordtouren-buchen.css
========================================================= */

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  margin:0;
  padding:0;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

body{
  margin:0;
  padding:0;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  position:relative;
  font-family:Arial, Helvetica, sans-serif;
  background:#f4f9fc;
  color:#16384f;
}

main,
section,
article,
aside,
div,
form,
label{
  max-width:100%;
}

img,
picture,
video,
canvas,
svg,
iframe{
  display:block;
  max-width:100%;
  height:auto;
}

input,
select,
textarea,
button{
  max-width:100%;
  font:inherit;
}

.dot-container{
  width:100%;
  max-width:1240px;
  margin:0 auto;
  padding-left:16px;
  padding-right:16px;
}

.dot-section{
  padding:56px 0;
}

.dot-section-head{
  text-align:center;
  margin-bottom:32px;
}

.dot-section-head h2{
  margin:0 0 12px;
  font-size:clamp(28px, 4vw, 42px);
  line-height:1.2;
  color:#0e3a5a;
}

.dot-section-head p{
  max-width:920px;
  margin:0 auto;
  font-size:18px;
  line-height:1.7;
  color:#456579;
}

.dot-safari-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.55fr) minmax(320px, 0.8fr);
  gap:28px;
  align-items:start;
}

.dot-safari-main,
.dot-safari-summary,
.dot-safari-form,
.dot-summary-box,
.dot-safari-card-grid,
.dot-safari-card,
.dot-safari-card__box,
.dot-safari-card__content,
.dot-safari-card__meta,
.dot-form-grid,
.dot-form-group,
.dot-form-actions{
  min-width:0;
  max-width:100%;
}

.dot-safari-form{
  background:#ffffff;
  border:1px solid #d9e7ef;
  border-radius:24px;
  box-shadow:0 10px 28px rgba(14,58,90,0.08);
  padding:30px;
}

.dot-form-block + .dot-form-block{
  margin-top:34px;
}

.dot-form-block h3{
  margin:0 0 10px;
  font-size:24px;
  line-height:1.3;
  color:#0e3a5a;
}

.dot-form-intro{
  margin:0 0 18px;
  font-size:16px;
  line-height:1.7;
  color:#5b7789;
}

.dot-label{
  display:block;
  margin:0 0 8px;
  font-size:15px;
  font-weight:700;
  line-height:1.45;
  color:#0e3a5a;
}

.dot-label--sub{
  margin-top:2px;
  font-size:14px;
  font-weight:400;
  color:#456579;
}

.dot-input,
.dot-textarea,
.dot-safari-card__select{
  width:100%;
  max-width:100%;
  min-width:0;
  font:inherit;
  color:#16384f;
  appearance:none;
  -webkit-appearance:none;
}

.dot-input{
  min-height:52px;
  margin:0 0 18px;
  padding:12px 14px;
  border:1px solid #cddbe5;
  border-radius:14px;
  background:#ffffff;
}

.dot-textarea{
  min-height:140px;
  margin:0;
  padding:12px 14px;
  border:1px solid #cddbe5;
  border-radius:14px;
  background:#ffffff;
  resize:vertical;
}

.dot-input:focus,
.dot-textarea:focus,
.dot-safari-card__select:focus{
  outline:none;
  border-color:#7ab8da;
  box-shadow:0 0 0 3px rgba(122,184,218,0.18);
}

.dot-form-group + .dot-form-group{
  margin-top:8px;
}

.dot-form-grid{
  display:grid;
  gap:16px;
}

.dot-form-grid--two{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.dot-form-grid--three{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.dot-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:15px;
  line-height:1.6;
  color:#456579;
}

.dot-check input{
  margin-top:4px;
}

.dot-form-actions{
  margin-top:28px;
}

.dot-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 26px;
  border:none;
  border-radius:999px;
  font:inherit;
  font-weight:700;
  text-decoration:none;
  text-align:center;
  cursor:pointer;
  transition:background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.dot-btn--primary{
  background:#27ae60;
  color:#ffffff;
  box-shadow:0 10px 24px rgba(39,174,96,0.24);
}

.dot-btn--primary:hover{
  background:#229954;
}

.dot-btn--primary:disabled{
  opacity:0.7;
  cursor:not-allowed;
  transform:none;
}

.dot-safari-card-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
}

.dot-safari-card-grid--single-option{
  grid-template-columns:1fr;
}

.dot-safari-card{
  display:block;
  min-width:0;
  cursor:pointer;
}

.dot-safari-card input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.dot-safari-card__box{
  display:flex;
  flex-direction:column;
  height:100%;
  overflow:hidden;
  border:2px solid #dbe7ee;
  border-radius:22px;
  background:#fdfefe;
  box-shadow:0 10px 26px rgba(14,58,90,0.06);
  transition:border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

.dot-safari-card:hover .dot-safari-card__box{
  border-color:#7ab8da;
  transform:translateY(-2px);
}

.dot-safari-card input:checked + .dot-safari-card__box{
  border-color:#27ae60;
  background:#eefaf2;
  box-shadow:0 0 0 1px rgba(39,174,96,0.18), 0 14px 30px rgba(39,174,96,0.10);
}

.dot-safari-card__image-wrap{
  display:block;
  aspect-ratio:16 / 10;
  overflow:hidden;
  background:#dfeef6;
}

.dot-safari-card__image-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.dot-safari-card__content{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:18px;
}

.dot-safari-card__category{
  display:block;
  font-size:13px;
  font-weight:700;
  letter-spacing:0.02em;
  text-transform:uppercase;
  color:#3d7394;
}

.dot-safari-card__title{
  display:block;
  font-size:22px;
  line-height:1.35;
  font-weight:700;
  color:#0e3a5a;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-safari-card__text{
  display:block;
  font-size:15px;
  line-height:1.7;
  color:#456579;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-safari-card__features{
  display:block;
  font-size:14px;
  line-height:1.7;
  color:#5e7c90;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-safari-card__meta{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-top:auto;
  padding-top:8px;
}

.dot-safari-card__price{
  font-size:28px;
  line-height:1.1;
  font-weight:800;
  color:#0e3a5a;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-safari-card__persons{
  font-size:15px;
  font-weight:700;
  color:#27ae60;
  text-align:right;
}

.dot-safari-card__availability{
  display:block;
  margin-top:4px;
  font-size:14px;
  font-weight:700;
  color:#3f6c86;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-safari-card__soldout-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  align-self:flex-start;
  min-height:44px;
  margin-top:8px;
  padding:10px 16px;
  border-radius:999px;
  background:#c62828;
  color:#ffffff;
  font-size:14px;
  font-weight:700;
  text-align:center;
}

.dot-safari-card__soldout-button[hidden]{
  display:none;
}

.dot-safari-card__select-wrap{
  display:block;
  margin-top:6px;
  padding:14px;
  border:1px solid #d9e7ef;
  border-radius:16px;
  background:#f8fcff;
}

.dot-safari-card__select-label{
  display:block;
  margin:0 0 8px;
  font-size:14px;
  font-weight:700;
  color:#0e3a5a;
}

.dot-safari-card__select{
  min-height:48px;
  padding:10px 12px;
  border:1px solid #cddbe5;
  border-radius:12px;
  background:#ffffff;
}

.dot-summary-box{
  position:sticky;
  top:24px;
  background:#ffffff;
  border:1px solid #d9e7ef;
  border-radius:24px;
  box-shadow:0 10px 28px rgba(14,58,90,0.08);
  padding:24px;
}

.dot-summary-box h3{
  margin:0 0 18px;
  font-size:24px;
  line-height:1.3;
  color:#0e3a5a;
}

.dot-summary-line{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:12px 0;
  border-bottom:1px solid #e2edf3;
  font-size:16px;
  line-height:1.5;
  color:#456579;
}

.dot-summary-line strong{
  color:#0e3a5a;
  text-align:right;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-summary-total{
  display:flex;
  justify-content:space-between;
  gap:16px;
  margin-top:18px;
  padding-top:18px;
  border-top:2px solid #d6e5ed;
  font-size:22px;
  font-weight:800;
  line-height:1.35;
  color:#0e3a5a;
}

.dot-summary-total strong{
  text-align:right;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.dot-summary-note{
  margin:16px 0 0;
  font-size:14px;
  line-height:1.7;
  color:#617f92;
}

.dot-form-block--consent{
  margin-top:28px;
}

.dot-check--consent{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:16px 18px;
  border:1px solid #d9e7ef;
  border-radius:18px;
  background:#f8fcff;
  font-size:15px;
  line-height:1.7;
  color:#456579;
}

.dot-check--consent input{
  flex:0 0 auto;
  width:18px;
  height:18px;
  margin:3px 0 0;
}

.dot-check--consent span{
  display:block;
  flex:1 1 auto;
}

.dot-check--consent a{
  color:#0e3a5a;
  font-weight:700;
  text-decoration:none;
}

.dot-check--consent a:hover{
  text-decoration:underline;
}

@media (max-width: 1100px){
  .dot-safari-layout{
    grid-template-columns:minmax(0, 1.35fr) minmax(280px, 0.8fr);
    gap:24px;
  }

  .dot-safari-card__title{
    font-size:20px;
  }

  .dot-safari-card__price{
    font-size:24px;
  }
}

@media (max-width: 991px){
  .dot-section{
    padding:48px 0;
  }

  .dot-safari-layout{
    grid-template-columns:1fr;
    gap:24px;
  }

  .dot-summary-box{
    position:static;
  }
}

@media (max-width: 767px){
  html,
  body{
    overflow-x:hidden;
  }

  .dot-container{
    padding-left:10px;
    padding-right:10px;
  }

  .dot-section{
    padding:38px 0;
  }

  .dot-section-head{
    margin-bottom:24px;
  }

  .dot-section-head h2{
    font-size:30px;
    line-height:1.2;
  }

  .dot-section-head p{
    font-size:16px;
    line-height:1.65;
  }

  .dot-safari-layout,
  .dot-safari-card-grid,
  .dot-form-grid,
  .dot-form-grid--two,
  .dot-form-grid--three{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  .dot-safari-form{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:18px 16px;
    border-radius:20px;
    overflow:hidden;
  }

  .dot-summary-box{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:18px 16px;
    border-radius:20px;
    overflow:hidden;
  }

  .dot-form-block + .dot-form-block{
    margin-top:28px;
  }

  .dot-form-block h3{
    font-size:21px;
  }

  .dot-form-intro{
    font-size:15px;
    line-height:1.65;
    margin-bottom:16px;
  }

  .dot-input{
    min-height:50px;
    margin:0 0 16px;
    padding:11px 12px;
    border-radius:12px;
    font-size:16px;
  }

  .dot-textarea{
    min-height:130px;
    padding:11px 12px;
    border-radius:12px;
    font-size:16px;
  }

  .dot-form-grid{
    gap:14px;
  }

  .dot-form-grid--two,
  .dot-form-grid--three{
    grid-template-columns:1fr;
  }

  .dot-safari-card-grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .dot-safari-card,
  .dot-safari-card__box{
    width:100%;
    max-width:100%;
    min-width:0;
    overflow:hidden;
  }

  .dot-safari-card__content{
    gap:9px;
    padding:15px;
  }

  .dot-safari-card__title{
    font-size:19px;
    line-height:1.3;
  }

  .dot-safari-card__text{
    font-size:14px;
    line-height:1.65;
  }

  .dot-safari-card__features{
    font-size:13px;
    line-height:1.6;
  }

  .dot-safari-card__meta{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
    min-width:0;
  }

  .dot-safari-card__price{
    font-size:24px;
  }

  .dot-safari-card__persons{
    text-align:left;
    font-size:14px;
  }

  .dot-safari-card__availability{
    font-size:13px;
  }

  .dot-safari-card__select-wrap{
    padding:12px;
    border-radius:14px;
  }

  .dot-safari-card__select{
    min-height:46px;
    border-radius:12px;
    font-size:16px;
  }

  .dot-summary-box h3{
    font-size:21px;
    margin-bottom:14px;
  }

  .dot-summary-line{
    gap:10px;
    padding:10px 0;
    font-size:15px;
    flex-direction:column;
    align-items:flex-start;
    min-width:0;
  }

  .dot-summary-line strong{
    width:100%;
    text-align:left;
  }

  .dot-summary-total{
    gap:10px;
    margin-top:14px;
    padding-top:14px;
    font-size:20px;
    flex-direction:column;
    align-items:flex-start;
    min-width:0;
  }

  .dot-summary-total strong{
    width:100%;
    text-align:left;
  }

  .dot-summary-note{
    font-size:13px;
    line-height:1.6;
  }

  .dot-check,
  .dot-check--consent{
    font-size:14px;
    line-height:1.6;
  }

  .dot-check--consent{
    padding:14px;
    border-radius:16px;
  }

  .dot-btn{
    width:100%;
    max-width:100%;
    min-height:52px;
    padding:0 18px;
  }
}

@media (max-width: 480px){
  .dot-container{
    padding-left:8px;
    padding-right:8px;
  }

  .dot-section{
    padding:32px 0;
  }

  .dot-section-head h2{
    font-size:26px;
  }

  .dot-section-head p{
    font-size:15px;
  }

  .dot-safari-form{
    padding:16px 14px;
    border-radius:18px;
  }

  .dot-form-block h3{
    font-size:19px;
  }

  .dot-label{
    font-size:14px;
  }

  .dot-label--sub{
    font-size:13px;
  }

  .dot-input,
  .dot-textarea,
  .dot-safari-card__select{
    font-size:16px;
  }

  .dot-safari-card__content{
    padding:14px;
  }

  .dot-safari-card__title{
    font-size:18px;
  }

  .dot-safari-card__price{
    font-size:22px;
  }

  .dot-summary-box{
    padding:16px 14px;
    border-radius:18px;
  }

  .dot-summary-box h3{
    font-size:19px;
  }

  .dot-summary-line{
    font-size:14px;
  }

  .dot-summary-total{
    font-size:18px;
  }

  .dot-check--consent{
    gap:10px;
    padding:12px;
  }
}