.booking-page{
  padding:30px 0 60px;
  background:
    radial-gradient(circle at top left, rgba(12,150,156,.08), transparent 30%),
    linear-gradient(180deg, #f7fbfb 0%, #ffffff 32%);
}

.booking-form{
  display:block;
}

.booking-hero{
  margin-bottom:28px;
  position:relative;
}

.booking-header{
  margin-bottom:28px;
}

.booking-alert{
  border-radius:16px;
  margin-bottom:22px;
}

.page-title{
  margin:0;
  font-size:clamp(2rem, 4vw, 3.2rem);
  line-height:1.05;
  font-weight:800;
  letter-spacing:-.03em;
  color:#083436;
}

.booking-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.65fr) minmax(320px, .95fr);
  gap:28px;
  align-items:start;
}

.booking-main{
  display:grid;
  gap:22px;
}

.card-block{
  background:#fff;
  border:1px solid rgba(5,70,72,.08);
  border-radius:22px;
  box-shadow:0 10px 30px rgba(5,70,72,.06);
  padding:28px;
}

.section-head{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-bottom:22px;
}

.section-step{
  width:40px;
  height:40px;
  flex:0 0 40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:linear-gradient(135deg, #7cff8a 0%, #56dc74 100%);
  color:#083436;
  font-weight:800;
  box-shadow:0 12px 24px rgba(124,255,138,.22);
}

.section-head h3{
  margin:0;
  font-size:1.16rem;
  font-weight:800;
  color:#083436;
}

.section-head p{
  margin:6px 0 0;
  color:#61737c;
  line-height:1.6;
}

.price-box{
  display:grid;
  gap:12px;
  padding:18px;
  margin-bottom:22px;
  border:1px dashed rgba(12,150,156,.25);
  border-radius:18px;
  background:rgba(12,150,156,.045);
}

.price-box-head h4{
  margin:0;
  font-size:1rem;
  font-weight:800;
  color:#083436;
}

.price-box-head p{
  margin:4px 0 0;
  color:#6a7b84;
  font-size:.92rem;
}

.price-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border-radius:12px;
  background:#fff;
  border:1px solid rgba(5,70,72,.06);
  font-size:.96rem;
  transition:.2s ease;
}

.price-row.is-active{
  background:rgba(124,255,138,.18);
  border-color:rgba(12,150,156,.18);
}

.price-row span{
  color:#5e7079;
  font-weight:700;
}

.price-row strong{
  color:#0a7075;
  font-weight:800;
}

.price-note{
  margin-top:4px;
  color:#0a7075;
  font-size:.9rem;
  font-weight:700;
}

.form-grid{
  display:grid;
  gap:18px;
}

.two-col{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.field-group{
  display:flex;
  flex-direction:column;
}

.form-label{
  margin:0 0 8px;
  font-size:.95rem;
  font-weight:800;
  color:#083436;
}

.form-label span{
  color:#0c969c;
}

.field-help{
  margin-top:8px;
  font-size:.84rem;
  line-height:1.5;
  color:#758790;
}

.form-control,
.form-select{
  width:100%;
  min-height:54px;
  border:1px solid #dbe5e8;
  border-radius:14px;
  background:#fcfefe;
  color:#20343c;
  padding:.85rem 1rem;
  box-shadow:none;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease, transform .2s ease;
}

.form-control::placeholder{
  color:#92a6af;
}

.form-control:focus,
.form-select:focus{
  border-color:#0c969c;
  background:#fff;
  box-shadow:0 0 0 .22rem rgba(12,150,156,.12);
  outline:none;
}

.textarea-control{
  min-height:160px;
  resize:vertical;
  padding-top:1rem;
}

.increment-decrement{
  display:grid;
  grid-template-columns:52px minmax(0, 1fr) 52px;
  gap:10px;
}

.count-btn{
  border:1px solid #dbe5e8;
  border-radius:14px;
  background:#fff;
  color:#083436;
  font-size:1.3rem;
  font-weight:700;
  transition:.2s ease;
}

.count-btn:hover{
  border-color:#0c969c;
  color:#0a7075;
  transform:translateY(-1px);
}

.count-input{
  text-align:center;
  font-weight:800;
  font-size:1.02rem;
}

.booking-actions{
  margin-top:22px;
  display:grid;
  gap:18px;
}

.check-row{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
  color:#17363d;
  cursor:pointer;
}

.check-row input{
  width:18px;
  height:18px;
  accent-color:#0c969c;
}

.btn-proceed{
  width:100%;
  min-height:58px;
  border:0;
  border-radius:16px;
  background:linear-gradient(135deg, #0c969c 0%, #0a7075 100%);
  color:#fff;
  font-size:1rem;
  font-weight:800;
  letter-spacing:.01em;
  box-shadow:0 16px 30px rgba(10,112,117,.22);
  transition:transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.btn-proceed:hover{
  transform:translateY(-1px);
  box-shadow:0 20px 34px rgba(10,112,117,.28);
}

.booking-sidebar{
  position: -webkit-sticky;
  position: sticky;
  top: 100px;
  align-self: start;
}

.summary-card{
  position: relative;
  background:linear-gradient(180deg, #083436 0%, #0f4d50 100%);
  color:#fff;
  border-radius:24px;
  padding:26px;
  box-shadow:0 24px 55px rgba(3,47,48,.18);
}
.summary-head p{
  margin:0 0 8px;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
}

.summary-head h4{
  margin:0 0 18px;
  font-size:1.34rem;
  line-height:1.45;
  font-weight:800;
  color:#fff;
}

.summary-meta-line{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.1);
}

.summary-meta-line:last-child{
  border-bottom:0;
}

.summary-meta-line span{
  color:rgba(255,255,255,.72);
  font-weight:600;
}

.summary-meta-line strong{
  color:#fff;
  font-weight:800;
  text-align:right;
}

.summary-list{
  margin-top:22px;
  display:grid;
  gap:0;
}

.summary-item{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.12);
}

.summary-item span{
  color:rgba(255,255,255,.76);
  font-weight:600;
}

.summary-item strong{
  color:#7cff8a;
  font-weight:800;
  white-space:nowrap;
  text-align:right;
}

.summary-item.is-total strong{
  color:#fff;
  font-size:1.05rem;
}

@media (max-width: 991.98px){
  .booking-layout{
    grid-template-columns:1fr;
  }

  .summary-card{
    position:static;
  }
}

@media (max-width: 767.98px){
  .booking-page{
    padding:30px 0 60px;
  }

  .booking-hero{
    padding:24px;
    border-radius:22px;
  }

  .card-block,
  .summary-card{
    padding:20px;
  }

  .two-col{
    grid-template-columns:1fr;
  }

  .increment-decrement{
    grid-template-columns:48px minmax(0, 1fr) 48px;
  }

}