:root{
  --bg-main:#f6f9fc;
  --bg-alt:#eef6ff;
  --text-main:#0f172a;
  --text-muted:#475569;
  --primary:#2563eb;
  --primary-soft:#e0ecff;
  --border:#e5e7eb;
  --shadow:0 18px 40px rgba(15,23,42,0.10);
  --max:1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:linear-gradient(180deg,#f8fbff,#eef5fb);
  color:var(--text-main);
}
a{color:inherit;text-decoration:none}

.container{width:min(var(--max),calc(100% - 40px));margin:0 auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Topbar */
.topbar{background:#fff;border-bottom:1px solid var(--border)}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;padding:10px 0;gap:12px;flex-wrap:wrap}
.pill{background:var(--primary-soft);color:var(--primary);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700}
.topbar__link{color:var(--text-muted);font-size:13px}
.dot{color:#94a3b8}

/* Header */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border)}
.header__inner{display:flex;justify-content:space-between;align-items:center;padding:14px 0;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{width:42px;height:42px;border-radius:14px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:900}
.brand__name{font-weight:900}
.brand__tag{font-size:12px;color:var(--text-muted)}

/* Nav */
.nav{display:flex;align-items:center;position:relative}
.nav__toggle{display:none;width:44px;height:44px;border-radius:14px;border:1px solid var(--border);background:#fff;cursor:pointer}
.nav__toggleBars{display:block;width:18px;height:2px;background:#334155;margin:0 auto;position:relative}
.nav__toggleBars::before,.nav__toggleBars::after{content:"";position:absolute;left:0;width:18px;height:2px;background:#334155}
.nav__toggleBars::before{top:-6px}
.nav__toggleBars::after{top:6px}
.nav__menu{display:flex;gap:14px;align-items:center}
.nav__menu a{padding:10px 12px;border-radius:12px;color:var(--text-muted);font-weight:700}
.nav__menu a:hover{background:var(--primary-soft);color:var(--primary)}

/* Buttons */
.btn{background:var(--primary);color:#fff;border:none;padding:12px 18px;border-radius:14px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.btn:hover{background:#1d4ed8}
.btn--ghost{background:#fff;border:1px solid var(--border);color:var(--primary)}
.btn--small{padding:10px 14px}
.btn--block{width:100%}

/* Hero */
.hero{
  position:relative;
  padding:64px 0;
  background:#fff;
  overflow:hidden;
}

.hero__bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(255,255,255,.55),rgba(255,255,255,.88)),
    url("/images/home-background.jpg") center/cover no-repeat;
}
.hero__inner{position:relative;display:grid;grid-template-columns:1.2fr .9fr;gap:28px;align-items:start}
.hero h1{font-size:clamp(36px,4vw,54px);line-height:1.05;margin:0 0 12px}
.hero p{max-width:52ch;color:var(--text-muted);margin:0 0 16px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.hero__badges{display:flex;gap:12px;flex-wrap:wrap}
.badge{background:#fff;border:1px solid var(--border);padding:10px 14px;border-radius:16px;box-shadow:var(--shadow);min-width:160px}
.badge strong{display:block}
.badge span{color:var(--text-muted);font-size:12px}

/* Lead card */
.hero__card{background:#fff;border-radius:26px;box-shadow:var(--shadow);overflow:hidden}
.card__header{padding:18px;border-bottom:1px solid var(--border)}
.card__header h2{margin:0 0 6px}
.card__header p{margin:0;color:var(--text-muted);font-size:13px}
.form{padding:18px}
label{display:block;font-size:13px;color:var(--text-muted)}
input,select,textarea{width:100%;padding:12px;border-radius:14px;border:1px solid var(--border);margin-top:6px;font:inherit}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary)}
.form__row{margin-bottom:12px}
.form__row--split{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fineprint{margin:10px 0 0;color:var(--text-muted);font-size:12px;line-height:1.4}

/* Sections */
.section{padding:56px 0}
.section--alt{background:var(--bg-alt)}
.section__head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.section__head h2{margin:0;font-size:28px}
.section__head p{margin:0;color:var(--text-muted);max-width:65ch}

/* Tiles */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tile{position:relative;background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);min-height:210px}
.tile img{width:100%;height:100%;display:block;object-fit:cover;transform:scale(1.01)}
.tile__overlay{
  position:absolute;left:0;right:0;bottom:0;padding:14px;color:#fff;
  background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.74));
}
.tile__title{font-weight:900;font-size:16px;margin-bottom:4px}
.tile__meta{font-size:13px;opacity:.92}
.tile:hover{transform:translateY(-2px);transition:transform 160ms ease}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:#fff;border-radius:22px;padding:18px;box-shadow:var(--shadow)}
.card p{color:var(--text-muted)}
.bullets{margin:0;padding-left:18px}
.bullets li{margin:6px 0}

/* Booking */
.booking{background:#fff;border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.tabs{display:flex;background:var(--primary-soft)}
.tab{flex:1;padding:14px;font-weight:900;background:none;border:none;cursor:pointer;color:#334155}
.tab.is-active{background:#fff;color:var(--primary)}
.tabpanes{padding:14px}
.pane{display:none}
.pane.is-active{display:block}
.iframeShell{border-radius:18px;overflow:hidden;border:1px solid var(--border)}
iframe{width:100%;height:520px;border:0;display:block;background:#f8fafc}
.iframeHint{padding:10px 12px;color:var(--text-muted);font-size:12px;border-top:1px solid var(--border)}
code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:12px;background:#f1f5f9;padding:2px 6px;border-radius:10px;border:1px solid #e2e8f0}

/* Footer */
.footer{background:#fff;border-top:1px solid var(--border);padding:30px 0 42px}
.footer__inner{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer__brand{font-weight:900;margin-bottom:6px}
.footer__small{color:var(--text-muted)}
.footer__links{display:flex;gap:12px;flex-wrap:wrap;color:var(--text-muted)}
.footer__links a:hover{color:var(--primary)}

/* ==========================
   MODAL (THIS FIXES SCROLL)
   ========================== */

/* body lock (JS uses this class) */
body.modal-open{
  position: fixed;
  width: 100%;
  overflow: hidden;
}

.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:999;
}
.modal.is-open{display:block}

.modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.55);
}

.modal__panel{
  position: relative;
  width: min(980px, calc(100% - 32px));
  height: calc(100dvh - 48px);
  margin: 24px auto;
  border-radius: 26px;
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-columns: 1.1fr .9fr;
}

/* CRITICAL: grid children must be allowed to shrink or overflow scroll won’t work */
.modal__media,
.modal__body{min-height:0}

.modal__media{overflow:hidden}
.modal__media img{width:100%;height:100%;object-fit:cover;display:block}

.modal__body{
  padding:16px 18px 18px;
  overflow:auto;                     /* scroll lives HERE */
  -webkit-overflow-scrolling:touch;  /* iOS momentum */
  touch-action: pan-y;               /* allow finger scroll */
}

.modal__close{
  position:absolute;top:10px;right:10px;
  width:40px;height:40px;border-radius:14px;
  border:1px solid var(--border);
  background:#fff;cursor:pointer;font-weight:900;
  z-index:2;
}

.kicker{font-weight:900;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.muted{color:var(--text-muted)}

.modal__grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0 10px}
.miniMap,.priceBox{border:1px solid var(--border);border-radius:16px;background:#fff;padding:10px}
.miniMap__label,.priceBox__label{font-weight:900;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.miniMap img{width:100%;height:140px;object-fit:cover;border-radius:12px;display:block}
.priceBox__value{font-weight:900;font-size:18px;margin-bottom:6px}
.priceBox__note{color:var(--text-muted);font-size:12px;line-height:1.35}

.included{margin-top:12px;border:1px solid var(--border);border-radius:16px;background:#fff;padding:12px 12px 6px}
.included__title{font-weight:900;margin-bottom:6px}
.included__list{margin:0;padding-left:18px;color:var(--text-muted)}
.included__list li{margin:6px 0}

.plan{margin:12px 0 0;padding-left:18px}
.plan li{margin:8px 0;color:var(--text-muted)}

.modalSticky{position:sticky;bottom:0;margin-top:14px;padding-top:10px;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.9) 22%,#fff)}
.emailIt{border:1px solid var(--border);border-radius:16px;background:#fff;padding:12px;box-shadow:0 10px 28px rgba(15,23,42,.08)}
.emailIt__row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}
.emailIt__label input{margin-top:6px}

.modal__cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

/* Responsive */
@media(max-width:980px){
  .hero__inner{grid-template-columns:1fr}
  .tiles,.cards{grid-template-columns:1fr}
  iframe{height:460px}

  .modal__panel{
    grid-template-columns: 1fr;
    height: calc(100dvh - 24px);
    margin: 12px auto;
  }
  .modal__media{max-height:220px}
  .modal__media img{height:220px}
  .modal__grid{grid-template-columns:1fr}
  .emailIt__row{grid-template-columns:1fr}
}

@media(max-width:720px){
  .form__row--split{grid-template-columns:1fr}
  .nav__toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav__menu{
    position:absolute;right:0;top:56px;width:min(320px,calc(100vw - 40px));
    display:none;flex-direction:column;align-items:stretch;gap:6px;padding:10px;
    border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow)
  }
  .nav__menu.is-open{display:flex}
}
