.mab-wrap{max-width:1180px;margin:0 auto}

/* Grid wrapper */
.mab-services-grid{
  display:grid;
  gap:26px;
}
.mab-services-grid.mab-cols-1{grid-template-columns:1fr}
.mab-services-grid.mab-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.mab-services-grid.mab-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.mab-services-grid.mab-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* Shell */
.mab-shell{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:0;
  align-items:stretch;
}

/* Media */
.mab-layout-split .mab-media{
  min-height:520px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  border-radius:0;
}
.mab-media--empty{background:rgba(255,255,255,.04)}

/* Grid layout card */
.mab-layout-grid{max-width:100%}
.mab-layout-grid .mab-shell{
  grid-template-columns:1fr;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.20);
  background:#2f2f2f;
}
.mab-layout-grid .mab-media{
  min-height:220px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.mab-layout-grid .mab-panel{
  border:0;
  background:#2f2f2f;
}

/* Panel */
.mab-panel{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.22);
  padding:22px 22px 18px;
  color:#e8e8e8;
}
.mab-layout-grid .mab-panel{padding:18px 18px 18px}

/* Title */
.mab-title{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  border-bottom:1px solid rgba(255,255,255,.22);
  padding-bottom:12px;
  margin-bottom:14px;
}
.mab-title h2{
  margin:0;
  font-size:28px;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-weight:700;
}
.mab-layout-grid .mab-title{
  justify-content:center;
  border-bottom:0;
  padding-bottom:0;
  margin-bottom:12px;
}
.mab-layout-grid .mab-title h2{
  font-size:20px;
  letter-spacing:.08em;
  text-align:center;
}
.mab-range{font-size:12px;letter-spacing:.08em;text-transform:uppercase;opacity:.9;white-space:nowrap}
.mab-intro{opacity:.85;margin:0 0 14px}

/* Packages */
.mab-packages{
  max-height:340px;
  overflow:auto;
  padding-right:10px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:14px;
}
.mab-layout-grid .mab-packages{
  max-height:none;
  overflow:visible;
  padding-right:0;
  border-top:0;
  padding-top:0;
}

.mab-packages::-webkit-scrollbar{width:10px}
.mab-packages::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:10px}
.mab-packages-title{opacity:.85;font-weight:700;margin:0 0 10px}

.mab-pkg{display:block;padding:12px 10px;border-radius:12px}
.mab-pkg:hover{background:rgba(255,255,255,.05)}
.mab-pkg-row{display:grid;grid-template-columns:22px 1fr auto auto;gap:12px;align-items:center}
.mab-pkg input[type=radio]{width:16px;height:16px}
.mab-pkg-name{font-weight:700}
.mab-pkg-meta,.mab-pkg-price{opacity:.9}

.mab-toggle{display:inline-block;margin:8px 0 0 34px;font-size:13px;opacity:.9;text-decoration:underline;cursor:pointer}
.mab-details{margin:10px 0 0 34px;display:none;gap:12px}
.mab-details.is-open{display:flex;font-size: 16px;grid-template-columns:1fr 1fr}
.mab-details ul{margin:0;padding-left:18px;opacity:.85}

/* Single-package grid design (like your screenshot) */
.mab-grid-price-block{margin:10px 0 16px}
.mab-grid-sep{
  height:1px;
  background:rgba(255,255,255,.35);
  opacity:.7;
}
.mab-grid-price-amount{
  text-align:center;
  padding:10px 0;
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.9;
}

.mab-grid-pricing-title{
  opacity:.75;
  font-weight:700;
  margin:0 0 10px;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.mab-grid-single-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 0 10px;
}
.mab-grid-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.9);
  box-sizing:border-box;
  display:inline-block;
}
.mab-grid-single-label{font-weight:700;font-size:13px;opacity:.95}
.mab-grid-single-price{opacity:.85;font-weight:700}

/* Hide auto radio but keep it for JS */
.mab-auto-radio{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

/* Tick list */
.mab-grid-lines{
  list-style:none;
  margin:0;
  padding:0;
}
.mab-grid-lines li{
  position:relative;
  padding:7px 0 7px 22px;
  opacity:.88;
  font-size:12px;
  color:rgba(255,255,255,.8);
}
.mab-grid-lines li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:7px;
  opacity:.95;
  color:rgba(255,255,255,.9);
}

/* Book button */
.mab-book-wrap{margin-top:18px;display:flex;justify-content:center}
.mab-layout-split .mab-book-wrap{justify-content:flex-start}
.mab-book-btn{
  background:transparent;
  border:1px solid rgba(255,255,255,.65);
  color:#fff;
  border-radius:999px;
  padding:14px 34px;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:inline-block;
  cursor:pointer;
  min-width:170px;
}
.mab-book-btn:hover{background:rgba(255,255,255,.08)}

/* Modal */
.mab-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:99999}
.mab-modal.is-open{display:flex}
.mab-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75)}
.mab-modal-card{
  position:relative;
  max-width:980px;
  width:min(980px,94vw);
  max-height:88vh;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  background:#0b0b0b;
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  padding:18px;
}
.mab-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.mab-modal-head strong{letter-spacing:.08em;text-transform:uppercase}
.mab-modal-close{background:transparent;border:1px solid rgba(255,255,255,.35);color:#fff;border-radius:999px;padding:8px 12px;cursor:pointer}
.mab-modal-close:hover{background:rgba(255,255,255,.08)}

/* Summary */
.mab-summary{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:14px 16px;margin:0 0 14px}
.mab-summary-row{display:flex;justify-content:space-between;gap:14px;padding:8px 0}
.mab-summary-k{opacity:.75;font-size:13px;letter-spacing:.06em;text-transform:uppercase}
.mab-summary-v{font-weight:800;font-size:18px}

/* Booking UI */
.mab-booking-ui{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:14px 16px;margin:0 0 14px}
.mab-ui-row{display:grid;grid-template-columns:160px 1fr;gap:14px;align-items:center;margin-bottom:12px}
.mab-ui-label{opacity:.8;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.mab-ui-control{display:flex;gap:10px;flex-wrap:wrap}
.mab-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:10px 12px;cursor:pointer}
.mab-pill input{margin:0}
.mab-pill span{font-size:13px}

.mab-date{
  width:100%;
  background:#0b0b0b;
  color:#fff;
  border:1px solid rgba(255,255,255,.35);
  border-radius:10px;
  padding:12px 12px;
  font-size:16px;
  cursor:pointer;
}
.mab-date::placeholder{color:rgba(255,255,255,.6)}
.mab-range-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}

.mab-ui-days{margin-top:12px}
.mab-ui-days-title{font-weight:800;letter-spacing:.06em;text-transform:uppercase;font-size:12px;opacity:.85;margin-bottom:10px}

/* Schedule */
.mab-day-row{
  display:grid;
  grid-template-columns:140px 1fr 160px;
  gap:12px;
  align-items:center;
  padding:10px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  margin-bottom:10px;
}
.mab-day-date{font-weight:800;white-space:nowrap}
.mab-day-fixed{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:10px 10px;
  text-align:center;
  font-weight:800;
  letter-spacing:.02em;
}
.mab-select{
  width:100%;
  background:#ffffff;
  color:#111;
  border:1px solid rgba(0,0,0,.18);
  border-radius:10px;
  padding:10px 10px;
  font-size:16px;
}

/* GF slot loading */
.mab-form-loading{
  margin:12px 0 0;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.85);
  font-size:14px;
}

/* Gravity Forms inside modal */
.mab-modal-card .gform_wrapper{color:#eaeaea}
.mab-modal-card .gform_wrapper .gfield_label,
.mab-modal-card .gform_wrapper legend{color:#eaeaea}
.mab-modal-card .gform_wrapper input[type="text"],
.mab-modal-card .gform_wrapper input[type="email"],
.mab-modal-card .gform_wrapper input[type="tel"],
.mab-modal-card .gform_wrapper textarea,
.mab-modal-card .gform_wrapper select{
  background:#ffffff !important;
  color:#111111 !important;
  border:1px solid rgba(0,0,0,.18) !important;
  border-radius:10px !important;
  padding:12px 12px !important;
  font-size:16px !important;
}
.mab-modal-card .gform_wrapper .gfield_required{color:#fff}
.mab-modal-card .gform_wrapper .gform_button{
  background:#ffffff !important;
  color:#111111 !important;
  border:0 !important;
  border-radius:999px !important;
  padding:12px 18px !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}
.mab-modal-card .gform_wrapper .gform_button:hover{opacity:.9}

/* Hide GF storage fields */
.mab-modal-card .gform_wrapper .ff_pkg_display,
.mab-modal-card .gform_wrapper .ff_price_display,
.mab-modal-card .gform_wrapper .ff_total_display,
.mab-modal-card .gform_wrapper .ff_booking_type,
.mab-modal-card .gform_wrapper .ff_date_single,
.mab-modal-card .gform_wrapper .ff_time_slot,
.mab-modal-card .gform_wrapper .ff_date_start,
.mab-modal-card .gform_wrapper .ff_date_end,
.mab-modal-card .gform_wrapper .ff_days_display,
.mab-modal-card .gform_wrapper .ff_booking_details{display:none !important}

/* Bottom total */
.mab-total-footer{
  margin-top:14px;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  background:rgba(255,255,255,.06);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
}
.mab-total-footer-k{
  opacity:.75;
  font-size:13px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.mab-total-footer-v{
  font-weight:900;
  font-size:20px;
}
  .mab-services-grid.mab-cols-4{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:900px){
  .mab-services-grid.mab-cols-4,
  .mab-services-grid.mab-cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mab-shell{grid-template-columns:1fr}
  .mab-layout-split .mab-media{min-height:280px}
  .mab-title h2{font-size:22px}
}
@media (max-width:640px){
  .mab-services-grid{grid-template-columns:1fr !important}
  .mab-title h2{font-size:18px;letter-spacing:.06em}
  .mab-layout-split .mab-media{min-height:220px}
  .mab-panel{padding:16px 14px 14px}

  /* Modal full-screen on mobile */
  .mab-modal-card{
    width:100vw !important;
    max-width:100vw !important;
    max-height:100dvh !important;
    height:100dvh !important;
    border-radius:0 !important;
    padding:14px 14px 20px !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch;
  }
  .mab-modal{align-items:flex-end}

  .mab-ui-row{grid-template-columns:1fr;gap:6px}
  .mab-ui-label{font-size:11px}
  .mab-range-grid{grid-template-columns:1fr}
  .mab-day-row{grid-template-columns:1fr;gap:8px}
  .mab-day-date{margin-bottom:4px}
  .mab-summary-v{font-size:15px}
  .mab-modal-head strong{font-size:14px}
  .mab-pkg-row{grid-template-columns:22px 1fr auto}
  .mab-pkg-meta{display:none}
}

/* =====================================================
   RENTAL GALLERY
   ===================================================== */

/* Grid */
.mab-rg-wrap{max-width:1180px;margin:0 auto}

.mab-rg-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}

/* Card */
.mab-rg-card{
  cursor:pointer;
  background:#1e1e1e;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  overflow:hidden;
  transition:transform .22s ease, border-color .22s ease;
}
.mab-rg-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.38);
}

/* Card image */
.mab-rg-card-img{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  background:#111;
}
.mab-rg-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}
.mab-rg-card:hover .mab-rg-card-img img{transform:scale(1.04)}
.mab-rg-card-img-empty{width:100%;height:100%;background:rgba(255,255,255,.04)}

.mab-rg-card-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:opacity .22s ease;
}
.mab-rg-card:hover .mab-rg-card-overlay{opacity:1}
.mab-rg-card-overlay span{
  color:#fff;
  border:1px solid rgba(255,255,255,.7);
  border-radius:999px;
  padding:10px 22px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

/* Card info */
.mab-rg-card-info{
  padding:14px 16px 16px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.mab-rg-card-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
}
.mab-rg-card-name{
  font-weight:700;
  font-size:15px;
  letter-spacing:.02em;
  color:#eee;
  line-height:1.3;
  flex:1;
  min-width:0;
  word-break:break-word;
}
.mab-rg-card-price{
  font-size:14px;
  font-weight:800;
  color:#fff;
  white-space:nowrap;
  flex-shrink:0;
}
.mab-rg-card-per-day{
  font-size:11px;
  color:rgba(255,255,255,.45);
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-top:-2px;
}
.mab-rg-card-sizes{
  font-size:11px;
  color:rgba(255,255,255,.4);
  letter-spacing:.07em;
  text-transform:uppercase;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:6px;
  margin-top:2px;
}

/* Modal overlay */
.mab-rg-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:99999;
}
.mab-rg-modal.is-open{display:flex}
.mab-rg-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.80);
}

/* Modal card */
.mab-rg-modal-card{
  position:relative;
  width:min(960px,95vw);
  max-height:92vh;
  overflow:auto;
  background:#0d0d0d;
  border:1px solid rgba(255,255,255,.18);
  border-radius:20px;
  display:grid;
  grid-template-columns:1fr 1fr;
  -webkit-overflow-scrolling:touch;
}

/* Close button */
.mab-rg-close{
  position:absolute;
  top:14px;
  right:14px;
  z-index:10;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
  border-radius:999px;
  width:36px;
  height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:16px;
  line-height:1;
  transition:background .18s;
}
.mab-rg-close:hover{background:rgba(255,255,255,.2)}

/* Left: Slider */
.mab-rg-modal-left{
  background:#111;
  border-radius:20px 0 0 20px;
  overflow:hidden;
}
.mab-rg-slider{height:100%;display:flex;flex-direction:column}
.mab-rg-slider-main{
  position:relative;
  flex:1;
  overflow:hidden;
  background:#000;
}
.mab-rg-main-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:opacity .2s;
}

/* Arrows */
.mab-rg-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  border-radius:999px;
  width:40px;
  height:40px;
  cursor:pointer;
  font-size:24px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .18s;
  z-index:2;
}
.mab-rg-arrow:hover{background:rgba(0,0,0,.8)}
.mab-rg-prev{left:12px}
.mab-rg-next{right:12px}

/* Thumbnails */
.mab-rg-thumbs{
  display:flex;
  gap:8px;
  padding:10px;
  background:#0d0d0d;
  overflow-x:auto;
  flex-shrink:0;
}
.mab-rg-thumbs::-webkit-scrollbar{height:4px}
.mab-rg-thumbs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:4px}
.mab-rg-thumb{
  width:62px;
  height:78px;
  object-fit:cover;
  border-radius:8px;
  cursor:pointer;
  border:2px solid transparent;
  flex-shrink:0;
  transition:border-color .18s;
  opacity:.65;
}
.mab-rg-thumb.is-active{border-color:#fff;opacity:1}

/* Right: Details */
.mab-rg-modal-right{
  padding:32px 28px 28px;
  display:flex;
  flex-direction:column;
  gap:16px;
  overflow:auto;
  color:#eee;
}
.mab-rg-modal-name{
  margin:0;
  font-size:24px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding-right:40px;
}
.mab-rg-modal-price{
  font-size:18px;
  font-weight:700;
  color:rgba(255,255,255,.85);
  letter-spacing:.04em;
}
.mab-rg-modal-desc{
  margin:0;
  font-size:14px;
  line-height:1.65;
  opacity:.75;
}

/* Size selector */
.mab-rg-size-label{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.65;
  margin-bottom:10px;
}
.mab-rg-size-btns{display:flex;gap:8px;flex-wrap:wrap}
.mab-rg-size-btn{
  background:transparent;
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  border-radius:8px;
  padding:8px 16px;
  cursor:pointer;
  font-size:13px;
  letter-spacing:.04em;
  transition:background .18s, border-color .18s;
}
.mab-rg-size-btn:hover{background:rgba(255,255,255,.08)}
.mab-rg-size-btn.is-selected{
  background:#fff;
  color:#111;
  border-color:#fff;
  font-weight:700;
}

/* Date range */
.mab-rg-dates-label{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.65;
  margin-bottom:10px;
}
.mab-rg-dates-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mab-rg-date{
  width:100%;
  background:#1a1a1a;
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  border-radius:10px;
  padding:12px 12px;
  font-size:14px;
  cursor:pointer;
  box-sizing:border-box;
}
.mab-rg-date::placeholder{color:rgba(255,255,255,.4)}
.mab-rg-date:focus{outline:none;border-color:rgba(255,255,255,.55)}

/* Calc summary */
.mab-rg-calc{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:14px 16px;
}
.mab-rg-calc-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:6px 0;
  font-size:14px;
  opacity:.85;
}
.mab-rg-calc-total{
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:6px;
  padding-top:10px;
  font-weight:800;
  font-size:18px;
  opacity:1;
}

/* Book button */
.mab-rg-book-btn{
  background:transparent;
  border:1px solid rgba(255,255,255,.65);
  color:#fff;
  border-radius:999px;
  padding:14px 28px;
  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  width:100%;
  transition:background .18s;
  margin-top:auto;
}
.mab-rg-book-btn:hover{background:rgba(255,255,255,.08)}
.mab-rg-book-btn:disabled{opacity:.4;cursor:not-allowed}

/* Form slot */
.mab-rg-form-slot{
  grid-column:1/-1;
  padding:20px 24px 24px;
  max-height:92vh;
  overflow:auto;
}
.mab-rg-form-header{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.12);
  flex-wrap:wrap;
}
.mab-rg-form-back{
  background:transparent;
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  border-radius:999px;
  padding:7px 14px;
  cursor:pointer;
  font-size:12px;
  flex-shrink:0;
  white-space:nowrap;
  align-self:center;
}
.mab-rg-form-back:hover{background:rgba(255,255,255,.08)}

/* Compact horizontal summary chips */
.mab-rg-form-summary{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  flex:1;
}
.mab-rg-summ-chip{
  display:inline-flex;
  align-items:center;
  gap:5px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  padding:5px 12px;
  font-size:12px;
  white-space:nowrap;
}
.mab-rg-summ-chip-k{
  opacity:.55;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:10px;
}
.mab-rg-summ-chip-v{
  font-weight:700;
  color:#fff;
}
.mab-rg-summ-chip.is-total{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.3);
}
.mab-rg-summ-chip.is-total .mab-rg-summ-chip-v{font-size:13px}

/* Total footer inside rental form (same as anniversary) */
.mab-rg-total-footer{
  margin-top:14px;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  background:rgba(255,255,255,.06);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
}
.mab-rg-total-footer-k{
  opacity:.75;
  font-size:13px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.mab-rg-total-footer-v{
  font-weight:900;
  font-size:20px;
  color:#fff;
}

/* GF inside rental modal — same dark theme */
.mab-rg-modal-card .gform_wrapper{color:#eaeaea}
.mab-rg-modal-card .gform_wrapper .gfield_label,
.mab-rg-modal-card .gform_wrapper legend{color:#eaeaea}
.mab-rg-modal-card .gform_wrapper input[type="text"],
.mab-rg-modal-card .gform_wrapper input[type="email"],
.mab-rg-modal-card .gform_wrapper input[type="tel"],
.mab-rg-modal-card .gform_wrapper textarea,
.mab-rg-modal-card .gform_wrapper select{
  background:#fff !important;
  color:#111 !important;
  border:1px solid rgba(0,0,0,.18) !important;
  border-radius:10px !important;
  padding:12px !important;
  font-size:15px !important;
}
.mab-rg-modal-card .gform_wrapper .gfield_required{color:#fff}
.mab-rg-modal-card .gform_wrapper .gform_button{
  background:#fff !important;
  color:#111 !important;
  border:0 !important;
  border-radius:999px !important;
  padding:12px 24px !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  cursor:pointer !important;
}
/* Hide rental-irrelevant GF fields */
.mab-rg-modal-card .gform_wrapper .ff_booking_type,
.mab-rg-modal-card .gform_wrapper .ff_date_single,
.mab-rg-modal-card .gform_wrapper .ff_time_slot,
.mab-rg-modal-card .gform_wrapper .ff_pkg_display,
.mab-rg-modal-card .gform_wrapper .ff_price_display,
.mab-rg-modal-card .gform_wrapper .ff_total_display,
.mab-rg-modal-card .gform_wrapper .ff_date_start,
.mab-rg-modal-card .gform_wrapper .ff_date_end,
.mab-rg-modal-card .gform_wrapper .ff_days_display,
.mab-rg-modal-card .gform_wrapper .ff_booking_details,
.mab-rg-modal-card .gform_wrapper .ff_service_id,
.mab-rg-modal-card .gform_wrapper .ff_service_title,
.mab-rg-modal-card .gform_wrapper .ff_pkg_name,
.mab-rg-modal-card .gform_wrapper .ff_pkg_price{display:none !important}

/* Compact GF form inside rental modal */
.mab-rg-gf-wrap .gform_wrapper{margin:0 !important}
.mab-rg-gf-wrap .gform_body{padding:0 !important}
.mab-rg-gf-wrap .gform_fields{gap:10px !important}
.mab-rg-gf-wrap .gfield{margin-bottom:0 !important;padding:0 !important}
.mab-rg-gf-wrap .gfield_label{margin-bottom:4px !important;font-size:12px !important;letter-spacing:.05em}
.mab-rg-gf-wrap .gform_wrapper input[type="text"],
.mab-rg-gf-wrap .gform_wrapper input[type="email"],
.mab-rg-gf-wrap .gform_wrapper input[type="tel"],
.mab-rg-gf-wrap .gform_wrapper textarea{
  padding:9px 10px !important;
  font-size:14px !important;
}
.mab-rg-gf-wrap .gform_wrapper textarea{min-height:70px !important;resize:vertical}

/* Responsive rental gallery */
@media (max-width:900px){
  .mab-rg-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .mab-rg-modal-card{
    grid-template-columns:1fr;
    width:100vw !important;
    max-width:100vw !important;
    max-height:100dvh !important;
    border-radius:0 !important;
  }
  .mab-rg-modal{align-items:flex-end}
  .mab-rg-modal-left{border-radius:0;min-height:260px;max-height:40dvh}
  .mab-rg-slider{min-height:260px;max-height:40dvh}
  .mab-rg-modal-right{padding:16px 16px 20px;overflow:visible}
  .mab-rg-form-slot{padding:14px 16px 20px}
}
@media (max-width:640px){
  .mab-rg-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .mab-rg-card-info{padding:10px 10px 12px}
  .mab-rg-card-name{font-size:12px}
  .mab-rg-card-price{font-size:12px}
  .mab-rg-card-per-day{font-size:10px}
  .mab-rg-card-sizes{font-size:10px}
  .mab-rg-modal-name{font-size:18px;padding-right:36px}
  .mab-rg-modal-price{font-size:15px}
  .mab-rg-dates-grid{grid-template-columns:1fr}
  .mab-rg-size-btns{gap:6px}
  .mab-rg-size-btn{padding:6px 12px;font-size:12px}
  .mab-rg-form-header{flex-direction:column;gap:10px}
  .mab-rg-form-summary{width:100%}
}
@media (max-width:400px){
  .mab-rg-grid{grid-template-columns:1fr}
}

/* =====================================================
   STANDALONE BOOK BUTTON [mab_book_btn]
   ===================================================== */
.mab-btn-only{
  display:inline-block;
  max-width:none;
  width:auto;
}
.mab-standalone-btn{
  background:transparent;
  border:1px solid rgba(255,255,255,.65);
  color:#fff;
  border-radius:999px;
  padding:14px 34px;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:inline-block;
  cursor:pointer;
  min-width:170px;
  font-size:14px;
  transition:background .18s;
}
.mab-standalone-btn:hover{background:rgba(255,255,255,.08)}

/* Package selector inside modal (for multi-pkg btn shortcode) */
.mab-modal-pkgs{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  padding:14px 16px;
  margin-bottom:14px;
  max-height:240px;
  overflow:auto;
}
.mab-modal-pkgs::-webkit-scrollbar{width:8px}
.mab-modal-pkgs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:8px}

/* =====================================================
   iOS / MOBILE GLOBAL FIXES
   ===================================================== */

/* Prevent iOS zoom on input focus — MUST be 16px+ */
.mab-date,
.mab-rg-date,
.mab-select,
.mab-modal-card input,
.mab-modal-card select,
.mab-modal-card textarea,
.mab-rg-modal-card input,
.mab-rg-modal-card select,
.mab-rg-modal-card textarea {
  font-size: 16px !important;
  -webkit-text-size-adjust: 100%;
}

/* Remove iOS input shadows and appearance */
.mab-date,
.mab-rg-date,
.mab-select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* Touch target minimum 44px for buttons */
.mab-book-btn,
.mab-standalone-btn,
.mab-modal-close,
.mab-rg-close,
.mab-rg-book-btn,
.mab-rg-form-back,
.mab-rg-arrow,
.mab-pill {
  min-height: 44px;
  -webkit-tap-highlight-color: transparent;
}

/* Pill radio labels touch fix */
.mab-pill {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
}

/* Smooth scroll inside modals on iOS */
.mab-modal-card,
.mab-rg-modal-card,
.mab-rg-modal-right,
.mab-rg-form-slot {
  -webkit-overflow-scrolling: touch;
}

  .mab-standalone-btn{
    width: 100%;
    min-width: unset;
    text-align: center;
  }
  .mab-btn-only{
    display: block;
    width: 100%;
  }
}

/* GF form inputs inside modals — iOS zoom prevention */
.mab-modal-card .gform_wrapper input[type="text"],
.mab-modal-card .gform_wrapper input[type="email"],
.mab-modal-card .gform_wrapper input[type="tel"],
.mab-modal-card .gform_wrapper input[type="number"],
.mab-modal-card .gform_wrapper select,
.mab-modal-card .gform_wrapper textarea,
.mab-rg-modal-card .gform_wrapper input[type="text"],
.mab-rg-modal-card .gform_wrapper input[type="email"],
.mab-rg-modal-card .gform_wrapper input[type="tel"],
.mab-rg-modal-card .gform_wrapper input[type="number"],
.mab-rg-modal-card .gform_wrapper select,
.mab-rg-modal-card .gform_wrapper textarea {
  font-size: 16px !important;
  -webkit-text-size-adjust: 100% !important;
}

/* Rental modal mobile full screen */
@media (max-width: 640px){
  .mab-rg-close{
    top: 10px;
    right: 10px;
    z-index: 20;
  }
  .mab-rg-thumbs{gap:6px;padding:8px}
  .mab-rg-thumb{width:48px;height:60px}
  .mab-rg-calc{padding:10px 12px}
  .mab-rg-calc-total{font-size:16px}
  .mab-rg-total-footer{padding:12px 14px}
  .mab-rg-total-footer-v{font-size:17px}
  .mab-rg-book-btn{padding:12px 20px;font-size:13px}

  /* Form summary chips wrap nicely */
  .mab-rg-form-summary{gap:6px}
  .mab-rg-summ-chip{padding:4px 10px;font-size:11px}
}

/* =====================================================
   PHOTOGRAPHY GALLERY  [mab_photo_gallery]
   ===================================================== */

.mab-pg-wrap{max-width:1100px;margin:0 auto}

.mab-pg-service{
  margin-bottom:56px;
  background:#0d0d0d;
  border-radius:20px;
  overflow:hidden;
  contain:layout style;
}
.mab-pg-service:last-child{margin-bottom:0}

/* ---- Slider ---- */
.mab-pg-slider{position:relative;background:#000;user-select:none;-webkit-user-select:none}
.mab-pg-slider-main{
  position:relative;width:100%;
  aspect-ratio:16/9;overflow:hidden;background:#111;
}
.mab-pg-main-img{
  width:100%;height:100%;object-fit:cover;display:block;
  opacity:1;transition:opacity .22s ease;will-change:opacity;
}
.mab-pg-img-empty{
  width:100%;height:100%;
  background:linear-gradient(135deg,#1a1a1a,#0d0d0d);
}

.mab-pg-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.18);
  color:#fff;width:44px;height:44px;border-radius:50%;
  font-size:24px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;z-index:2;
  -webkit-tap-highlight-color:transparent;
}
.mab-pg-arrow:hover{background:rgba(0,0,0,.8)}
.mab-pg-prev{left:14px}.mab-pg-next{right:14px}

.mab-pg-thumbs{
  display:flex;gap:8px;padding:10px 16px;
  overflow-x:auto;background:#0a0a0a;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;
}
.mab-pg-thumbs::-webkit-scrollbar{height:4px}
.mab-pg-thumbs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:4px}
.mab-pg-thumb{
  width:82px;height:55px;object-fit:cover;border-radius:7px;
  cursor:pointer;opacity:.45;transition:opacity .15s;
  flex-shrink:0;border:2px solid transparent;
  -webkit-tap-highlight-color:transparent;
}
.mab-pg-thumb.is-active{opacity:1;border-color:#fff}
.mab-pg-thumb:hover{opacity:.8}

.mab-pg-dots{
  display:none;justify-content:center;gap:7px;
  padding:8px 0;background:#0a0a0a;
}
.mab-pg-dot{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.3);cursor:pointer;
  transition:background .15s,transform .15s;
}
.mab-pg-dot.is-active{background:#fff;transform:scale(1.25)}

/* ---- Info ---- */
.mab-pg-info{padding:20px 26px 8px}
.mab-pg-name{
  font-size:20px;font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;
  color:#fff;margin:0 0 8px;
}
.mab-pg-desc{
  font-size:13px;color:rgba(255,255,255,.62);
  line-height:1.7;margin:0;
}

/* ---- Booking ---- */
.mab-pg-booking{
  padding:20px 26px 28px;
  display:grid;
  grid-template-columns:320px 1fr;
  gap:24px;
  align-items:start;
}

/* Date UI */
.mab-pg-date-ui{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:16px;
  display:flex;flex-direction:column;gap:12px;
}

/* Mode pills row */
.mab-pg-mode-row{display:flex;gap:8px;flex-wrap:wrap}

.mab-pg-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border:1px solid rgba(255,255,255,.22);
  border-radius:999px;cursor:pointer;font-size:12px;
  color:rgba(255,255,255,.72);transition:all .15s;
  min-height:36px;-webkit-tap-highlight-color:transparent;
}
.mab-pg-pill:has(input:checked){
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.5);color:#fff;
}
.mab-pg-pill input{width:0;height:0;opacity:0;position:absolute}

/* Field label */
.mab-pg-field-label{
  display:block;font-size:11px;text-transform:uppercase;
  letter-spacing:.07em;color:rgba(255,255,255,.45);
  margin-bottom:6px;
}

/* Single / range rows */
.mab-pg-single-row,.mab-pg-range-row,.mab-pg-days-row{display:block}

.mab-pg-date{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;color:#fff;
  padding:9px 12px;font-size:16px !important;
  width:100%;box-sizing:border-box;cursor:pointer;
  transition:border-color .15s;
}
.mab-pg-date:focus{border-color:rgba(255,255,255,.45);outline:none}

.mab-pg-range-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
}

.mab-pg-days-row{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:rgba(255,255,255,.55);
}
.mab-pg-days-count{font-weight:700;font-size:15px;color:#fff}

/* GF wrap */
.mab-pg-gf-wrap{min-width:0}
.mab-pg-gf-wrap .gform_wrapper{margin:0 !important}
.mab-pg-gf-wrap .gform_body{padding:0 !important}
.mab-pg-gf-wrap .gform_fields{gap:10px !important}
.mab-pg-gf-wrap .gfield{margin-bottom:0 !important;padding:0 !important}
.mab-pg-gf-wrap .gfield_label{font-size:12px !important;margin-bottom:4px !important}
.mab-pg-gf-wrap .gform_wrapper input[type="text"],
.mab-pg-gf-wrap .gform_wrapper input[type="email"],
.mab-pg-gf-wrap .gform_wrapper input[type="tel"],
.mab-pg-gf-wrap .gform_wrapper select,
.mab-pg-gf-wrap .gform_wrapper textarea{font-size:16px !important;padding:9px 12px !important}
.mab-pg-gf-wrap .gform_wrapper textarea{min-height:70px !important;resize:vertical}

/* Hide all backend/hidden fields from user */
.mab-pg-gf-wrap .ff_pkg_display,
.mab-pg-gf-wrap .ff_price_display,
.mab-pg-gf-wrap .ff_total_display,
.mab-pg-gf-wrap .ff_booking_type,
.mab-pg-gf-wrap .ff_date_single,
.mab-pg-gf-wrap .ff_time_slot,
.mab-pg-gf-wrap .ff_date_start,
.mab-pg-gf-wrap .ff_date_end,
.mab-pg-gf-wrap .ff_days_display,
.mab-pg-gf-wrap .ff_service_id,
.mab-pg-gf-wrap .ff_service_title,
.mab-pg-gf-wrap .ff_photo_name,
.mab-pg-gf-wrap .ff_pkg_name,
.mab-pg-gf-wrap .ff_pkg_price,
.mab-pg-gf-wrap .ff_booking_details{display:none !important}

/* ---- Responsive ---- */
@media (max-width:960px){
  .mab-pg-booking{grid-template-columns:1fr;gap:18px;padding:14px 20px 22px}
  .mab-pg-info{padding:16px 20px 6px}
}
@media (max-width:640px){
  .mab-pg-slider-main{aspect-ratio:4/3}
  .mab-pg-thumbs{display:none}
  .mab-pg-dots{display:flex}
  .mab-pg-range-grid{grid-template-columns:1fr}
  .mab-pg-info{padding:12px 14px 4px}
  .mab-pg-booking{padding:10px 14px 18px}
  .mab-pg-name{font-size:15px}
  .mab-pg-service{border-radius:12px;margin-bottom:28px}
  .mab-pg-arrow{width:36px;height:36px;font-size:20px}
  .mab-pg-prev{left:8px}.mab-pg-next{right:8px}
  .mab-pg-date-ui{padding:12px}
}

/* =====================================================
   MAKEUP GALLERY  [mab_makeup_gallery]
   ===================================================== */

.mab-mk-wrap{
  position:relative;
  max-width:1200px;
  margin:0 auto;
}

/* ---- Grid ---- */
.mab-mk-grid{
  display:grid;
  gap:24px;
}
.mab-mk-cols-3{ grid-template-columns:repeat(3,1fr); }
.mab-mk-cols-2{ grid-template-columns:repeat(2,1fr); }
.mab-mk-cols-4{ grid-template-columns:repeat(4,1fr); }
.mab-mk-cols-1{ grid-template-columns:1fr; }

/* ---- Card ---- */
.mab-mk-card{
  background:#0d0d0d;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:border-color .2s, transform .2s;
  contain:layout style;
}
.mab-mk-card:hover{
  border-color:rgba(255,255,255,.22);
  transform:translateY(-3px);
}

.mab-mk-card-img{
  position:relative;
  width:100%;
  aspect-ratio:3/4;
  overflow:hidden;
  background:#111;
  flex-shrink:0;
}
.mab-mk-card-img img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .4s ease;
}
.mab-mk-card:hover .mab-mk-card-img img{
  transform:scale(1.04);
}
.mab-mk-card-img-empty{
  width:100%;height:100%;
  background:linear-gradient(135deg,#1a1a1a,#0a0a0a);
}

.mab-mk-card-body{
  padding:18px 20px 20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}
.mab-mk-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.mab-mk-card-name{
  font-size:17px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#fff;
  margin:0;
  line-height:1.2;
}
.mab-mk-card-price{
  font-size:11px;
  font-weight:700;
  color:rgba(255,255,255,.6);
  text-decoration:underline;
  text-underline-offset:3px;
  white-space:nowrap;
  flex-shrink:0;
  margin-top:2px;
}
.mab-mk-card-desc{
  font-size:13px;
  color:rgba(255,255,255,.55);
  line-height:1.6;
  margin:0;
  flex:1;
}
.mab-mk-book-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:auto;
  padding:10px 20px;
  background:transparent;
  border:1px solid rgba(255,255,255,.55);
  color:#fff;
  font-size:12px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  border-radius:4px;
  cursor:pointer;
  transition:background .15s, border-color .15s;
  -webkit-tap-highlight-color:transparent;
  width:fit-content;
}
.mab-mk-book-btn:hover{
  background:rgba(255,255,255,.1);
  border-color:#fff;
}
.mab-mk-arrow{ font-size:14px; }

/* ---- Modal ---- */
.mab-mk-modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:99999;
  align-items:center;
  justify-content:center;
}
.mab-mk-modal.is-open{ display:flex; }

.mab-mk-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}

.mab-mk-modal-box{
  position:relative;
  z-index:1;
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  width:min(900px,96vw);
  max-height:90dvh;
  overflow-y:auto;
  overscroll-behavior:contain;
  display:flex;
  flex-direction:column;
  animation:mkModalIn .22s ease;
}
@keyframes mkModalIn{
  from{opacity:0;transform:translateY(16px) scale(.97)}
  to  {opacity:1;transform:none}
}

.mab-mk-close{
  position:absolute;
  top:14px;right:16px;
  background:rgba(255,255,255,.08);
  border:none;
  color:rgba(255,255,255,.7);
  width:34px;height:34px;
  border-radius:50%;
  font-size:16px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
  z-index:2;
  -webkit-tap-highlight-color:transparent;
}
.mab-mk-close:hover{ background:rgba(255,255,255,.18); color:#fff; }

.mab-mk-modal-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
}

/* Left panel */
.mab-mk-modal-left{
  padding:28px 24px 28px 28px;
  border-right:1px solid rgba(255,255,255,.08);
  display:flex;
  flex-direction:column;
  gap:20px;
}
.mab-mk-modal-title{
  font-size:18px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:#fff;
  margin:0;
  padding-right:30px;
}

/* Types */
.mab-mk-types-label,
.mab-mk-mode-label,
.mab-mk-date-label{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.09em;
  color:rgba(255,255,255,.4);
  margin-bottom:8px;
  display:block;
}
.mab-mk-types-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.mab-mk-type-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  cursor:pointer;
  transition:background .15s, border-color .15s;
  -webkit-tap-highlight-color:transparent;
}
.mab-mk-type-item:has(input:checked){
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.3);
}
.mab-mk-type-item input[type="checkbox"]{
  width:16px;height:16px;
  accent-color:#fff;
  flex-shrink:0;
  margin-top:2px;
  cursor:pointer;
}
.mab-mk-type-info{
  display:flex;
  flex-direction:column;
  gap:2px;
  flex:1;
  min-width:0;
}
.mab-mk-type-name{
  font-size:13px;
  font-weight:600;
  color:#fff;
}
.mab-mk-type-desc{
  font-size:11px;
  color:rgba(255,255,255,.5);
  line-height:1.4;
}
.mab-mk-type-price{
  font-size:11px;
  font-weight:700;
  color:rgba(255,255,255,.6);
  margin-top:2px;
}

/* Mode pills */
.mab-mk-mode-btns{ display:flex; gap:8px; flex-wrap:wrap; }
.mab-mk-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;cursor:pointer;font-size:12px;
  color:rgba(255,255,255,.7);transition:all .15s;
  min-height:36px;-webkit-tap-highlight-color:transparent;
}
.mab-mk-pill:has(input:checked){
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.5);color:#fff;
}
.mab-mk-pill input{ width:0;height:0;opacity:0;position:absolute; }

/* Date inputs */
.mab-mk-date-inp{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;color:#fff;
  padding:9px 12px;font-size:16px !important;
  width:100%;box-sizing:border-box;cursor:pointer;
  transition:border-color .15s;
}
.mab-mk-date-inp:focus{ border-color:rgba(255,255,255,.45);outline:none; }
.mab-mk-range-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
}
.mab-mk-days-row{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:rgba(255,255,255,.5);
}
.mab-mk-days-val{ font-weight:700;font-size:15px;color:#fff; }

/* Right panel — GF */
.mab-mk-modal-right{
  padding:28px 28px 28px 24px;
}
.mab-mk-gf-wrap .gform_wrapper{ margin:0 !important; }
.mab-mk-gf-wrap .gform_body{ padding:0 !important; }
.mab-mk-gf-wrap .gform_fields{ gap:10px !important; }
.mab-mk-gf-wrap .gfield{ margin-bottom:0 !important;padding:0 !important; }
.mab-mk-gf-wrap .gfield_label{ font-size:12px !important;margin-bottom:4px !important; }
.mab-mk-gf-wrap .gform_wrapper input[type="text"],
.mab-mk-gf-wrap .gform_wrapper input[type="email"],
.mab-mk-gf-wrap .gform_wrapper input[type="tel"],
.mab-mk-gf-wrap .gform_wrapper select,
.mab-mk-gf-wrap .gform_wrapper textarea{ font-size:16px !important;padding:9px 12px !important; }
.mab-mk-gf-wrap .gform_wrapper textarea{ min-height:70px !important;resize:vertical; }

/* Hide backend fields */
.mab-mk-gf-wrap .ff_pkg_display,
.mab-mk-gf-wrap .ff_price_display,
.mab-mk-gf-wrap .ff_total_display,
.mab-mk-gf-wrap .ff_booking_type,
.mab-mk-gf-wrap .ff_date_single,
.mab-mk-gf-wrap .ff_time_slot,
.mab-mk-gf-wrap .ff_date_start,
.mab-mk-gf-wrap .ff_date_end,
.mab-mk-gf-wrap .ff_days_display,
.mab-mk-gf-wrap .ff_service_id,
.mab-mk-gf-wrap .ff_service_title,
.mab-mk-gf-wrap .ff_photo_name,
.mab-mk-gf-wrap .ff_pkg_name,
.mab-mk-gf-wrap .ff_pkg_price,
.mab-mk-gf-wrap .ff_booking_details{ display:none !important; }

/* ---- Responsive ---- */
@media (max-width:1024px){
  .mab-mk-cols-3,.mab-mk-cols-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:720px){
  .mab-mk-modal-inner{ grid-template-columns:1fr; }
  .mab-mk-modal-left{ border-right:none; border-bottom:1px solid rgba(255,255,255,.08); padding:22px 18px; }
  .mab-mk-modal-right{ padding:20px 18px 24px; }
  .mab-mk-range-grid{ grid-template-columns:1fr; }
  .mab-mk-modal-box{ width:100vw;max-height:100dvh;border-radius:20px 20px 0 0;margin-top:auto; }
  .mab-mk-modal{ align-items:flex-end; }
}
@media (max-width:540px){
  .mab-mk-cols-2,.mab-mk-cols-3,.mab-mk-cols-4{ grid-template-columns:1fr; }
  .mab-mk-grid{ gap:16px; }
}


/* ═══════════════════════════════════════════════════════
   DATEPICKER — field ke neeche show ho, screen aware
   ═══════════════════════════════════════════════════════ */

/* Overlay: tap outside = close picker */
.mab-dp-overlay{
  position:fixed;
  inset:0;
  z-index:2147483640;
  background:transparent;
}

/* Base picker styles — positioning is set by JS (below/above field) */
.ui-datepicker{
  z-index:2147483647 !important;
  width:280px !important;
  background:#111 !important;
  border:1px solid rgba(255,255,255,.2) !important;
  border-radius:12px !important;
  padding:12px !important;
  box-shadow:0 8px 32px rgba(0,0,0,.7) !important;
  color:#fff !important;
  /* no position/top/left here — JS handles that */
}
.ui-datepicker table{
  width:100% !important;
  border-collapse:separate;
  border-spacing:2px;
}
.ui-datepicker .ui-datepicker-header{
  background:transparent !important;
  border:none !important;
  padding:4px 36px 10px !important;
  position:relative;
  color:#fff !important;
  text-align:center;
}
.ui-datepicker .ui-datepicker-title{
  font-weight:700;
  font-size:13px;
  letter-spacing:.04em;
  line-height:1;
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next{
  position:absolute !important;
  top:4px !important;
  width:28px !important;
  height:28px !important;
  cursor:pointer;
  border-radius:6px !important;
  background:rgba(255,255,255,.08) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.ui-datepicker .ui-datepicker-prev{ left:0 !important; }
.ui-datepicker .ui-datepicker-next{ right:0 !important; }
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span{
  display:block !important;
  overflow:visible !important;
  text-indent:0 !important;
  background:none !important;
  color:#fff !important;
  font-size:11px;
}
.ui-datepicker th{
  color:rgba(255,255,255,.4) !important;
  font-size:9px !important;
  font-weight:700 !important;
  text-transform:uppercase;
  padding:2px !important;
  text-align:center;
}
.ui-datepicker td{ padding:2px !important; }
.ui-datepicker .ui-state-default{
  display:block;
  text-align:center;
  padding:6px 2px !important;
  font-size:12px !important;
  line-height:1.2;
  border-radius:6px !important;
  background:rgba(255,255,255,.07) !important;
  border:1px solid rgba(255,255,255,.09) !important;
  color:#fff !important;
}
.ui-datepicker .ui-state-active{
  background:#fff !important;
  color:#111 !important;
  font-weight:700 !important;
  border-color:transparent !important;
}
.ui-datepicker .ui-datepicker-today .ui-state-default{
  border-color:rgba(255,255,255,.4) !important;
}
.ui-datepicker .ui-state-disabled span{ opacity:.25 !important; }
.ui-datepicker .ui-state-hover{
  background:rgba(255,255,255,.13) !important;
}

/* Mobile ≤ 640px — full-width bottom sheet style */
@media(max-width:768px){
  .ui-datepicker{
    position:fixed !important;
    left:0 !important;
    right:0 !important;
    bottom: -50px !important;
    top:auto !important;
    transform:none !important;
    width:100% !important;
    max-width:100% !important;
    border-radius:20px 20px 0 0 !important;
    padding:16px 16px 32px !important;
    border-bottom:none !important;
  }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — All modals, all screen sizes
   ══════════════════════════════════════════════════════════════ */

/* Base modal card — already has max-height:88vh + overflow:auto */
.mab-modal-card{
  box-sizing:border-box;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.2) transparent;
}
.mab-modal-card::-webkit-scrollbar{ width:5px; }
.mab-modal-card::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.2); border-radius:4px; }

/* Tablet ≤ 900px */
@media(max-width:900px){
  .mab-modal-card{
    padding:16px !important;
    max-height:92vh !important;
  }
  .mab-summary-v{ font-size:16px !important; }
}

/* Mobile ≤ 640px — slide up from bottom, full width */
@media(max-width:640px){
  .mab-modal{
    align-items:flex-end !important;
  }
  .mab-modal-card{
    width:100vw !important;
    max-width:100vw !important;
    max-height:92dvh !important;
    border-radius:20px 20px 0 0 !important;
    padding:16px 14px 24px !important;
  }
  .mab-ui-row{ flex-wrap:wrap; gap:8px; }
  .mab-range-grid{
    grid-template-columns:1fr !important;
    gap:8px !important;
  }
  .mab-summary-v{ font-size:15px !important; }
  .mab-ui-days-list{ gap:8px !important; }
}

/* Small phones ≤ 400px */
@media(max-width:400px){
  .mab-modal-card{ padding:12px 10px 20px !important; }
  .mab-modal-head strong{ font-size:12px !important; }
}

/* ── Service / book_btn modal booking UI ── */
@media(max-width:640px){
  .mab-booking-ui .mab-ui-row{
    flex-direction:column;
    gap:6px;
  }
  .mab-ui-label{
    font-size:12px !important;
    margin-bottom:0 !important;
  }
  .mab-ui-control{ width:100% !important; }
  .mab-date{
    width:100% !important;
    box-sizing:border-box;
  }
  .mab-pill{ flex:1 !important; }
  .mab-pill span{ width:100%; text-align:center; }
}

/* ── Rental gallery modal responsive ── */
@media(max-width:900px){
  .mab-rg-modal-card{
    grid-template-columns:1fr !important;
    grid-template-rows:auto 1fr !important;
    max-height:94dvh !important;
    overflow-y:auto !important;
  }
  .mab-rg-modal-left{
    min-height:200px !important;
    max-height:36dvh !important;
  }
}
@media(max-width:640px){
  .mab-rg-modal{
    align-items:flex-end !important;
  }
  .mab-rg-modal-card{
    width:100vw !important;
    max-width:100vw !important;
    border-radius:20px 20px 0 0 !important;
    max-height:94dvh !important;
  }
  .mab-rg-dates-grid{
    grid-template-columns:1fr !important;
    gap:8px !important;
  }
  .mab-rg-date{ width:100% !important; box-sizing:border-box; }
}

/* ── Photo gallery responsive ── */
@media(max-width:768px){
  .mab-pg-booking{
    grid-template-columns:1fr !important;
  }
  .mab-pg-date-ui{ border-right:none !important; border-bottom:1px solid rgba(255,255,255,.1); padding-bottom:16px !important; }
  .mab-pg-gf-wrap{ padding-top:16px !important; }
  .mab-pg-range-grid{
    grid-template-columns:1fr !important;
    gap:8px !important;
  }
}

/* ── Makeup gallery modal responsive ── */
@media(max-width:640px){
  .mab-mk-modal{
    align-items:flex-end !important;
  }
  .mab-mk-modal-card{
    width:100vw !important;
    max-width:100vw !important;
    border-radius:20px 20px 0 0 !important;
    max-height:94dvh !important;
    overflow-y:auto !important;
  }
}

/* ── GF form inside all modals — responsive ── */
.mab-modal-card .gform_wrapper,
.mab-rg-gf-wrap .gform_wrapper,
.mab-pg-gf-wrap .gform_wrapper,
.mab-mk-gf-wrap .gform_wrapper,
#mab-gf-holders .gform_wrapper{
  max-width:100% !important;
  box-sizing:border-box;
}
.mab-modal-card .gform_wrapper input[type="text"],
.mab-modal-card .gform_wrapper input[type="email"],
.mab-modal-card .gform_wrapper input[type="tel"],
.mab-modal-card .gform_wrapper input[type="number"],
.mab-modal-card .gform_wrapper textarea,
.mab-modal-card .gform_wrapper select,
.mab-rg-gf-wrap .gform_wrapper input[type="text"],
.mab-rg-gf-wrap .gform_wrapper input[type="email"],
.mab-rg-gf-wrap .gform_wrapper input[type="tel"],
.mab-rg-gf-wrap .gform_wrapper textarea,
.mab-rg-gf-wrap .gform_wrapper select,
.mab-pg-gf-wrap .gform_wrapper input[type="text"],
.mab-pg-gf-wrap .gform_wrapper input[type="email"],
.mab-pg-gf-wrap .gform_wrapper input[type="tel"],
.mab-pg-gf-wrap .gform_wrapper textarea,
.mab-pg-gf-wrap .gform_wrapper select,
.mab-mk-gf-wrap .gform_wrapper input[type="text"],
.mab-mk-gf-wrap .gform_wrapper input[type="email"],
.mab-mk-gf-wrap .gform_wrapper input[type="tel"],
.mab-mk-gf-wrap .gform_wrapper textarea,
.mab-mk-gf-wrap .gform_wrapper select{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
  font-size:16px !important; /* prevent iOS zoom */
}
@media(max-width:640px){
  .mab-modal-card .gform_wrapper .gform_fields,
  .mab-rg-gf-wrap .gform_wrapper .gform_fields,
  .mab-pg-gf-wrap .gform_wrapper .gform_fields,
  .mab-mk-gf-wrap .gform_wrapper .gform_fields{
    grid-template-columns:1fr !important;
  }
}

