:root{
  --navy:#0b1f3b;
  --navy-900:#071429;
  --orange:#ff7a00;
  --white:#fff;

  --wrap:1180px;
  --pad-x:28px;

  --brand-font:"Bebas Neue","Impact",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --hero-shift-x:-30px;

  --form-font:14px;
  --bullet-font:10px;
  --notice-font:9px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body.kc{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:#eaf0ff;background:var(--navy-900);overflow-x:hidden
}

/* ===========================
   Header
=========================== */
.kc-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.95);
  backdrop-filter:saturate(160%) blur(6px);
  box-shadow:0 1px 0 rgba(0,0,0,.08)
}
.header-wrap{
  max-width:var(--wrap);margin-inline:auto;
  display:grid;
  grid-template-columns:max-content 1fr max-content; /* content-sized logo & button */
  align-items:center;column-gap:16px;
  padding:10px var(--pad-x);
  white-space:nowrap
}
.logo{height:46px;width:auto;display:block}
.tabs{
  display:flex;align-items:center;justify-content:center;
  gap:26px;min-width:0;max-width:100%; /* center can shrink; never pushes button */
  overflow:hidden;text-overflow:ellipsis
}
.tabs .tab{
  position:relative;display:inline-block;text-decoration:none;color:var(--navy);
  font-family:var(--brand-font);font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;font-size:16px;padding:10px 2px
}
.tabs .tab::after{
  content:"";position:absolute;left:50%;bottom:4px;transform:translateX(-50%);
  width:72%;height:3px;background:var(--orange);border-radius:2px
}
.btn{
  appearance:none;border-radius:999px;padding:12px 18px;
  font-family:var(--brand-font);font-weight:700;letter-spacing:.06em;
  text-decoration:none;display:inline-flex;align-items:center;justify-content:center
}
.btn.cta{
  background:var(--orange);color:#fff;border:2px solid var(--orange);font-size:14px;
  width:auto;min-width:0;flex:0 0 auto;white-space:nowrap;justify-self:end;align-self:center
}
.btn.cta:hover{filter:brightness(.95)}

/* Keep a hard right gutter for the button (at least 16px) */
.header-wrap{padding-right:16px}
@media (min-width:1200px){
  .header-wrap{padding-right:20px}
}

/* Make header fit on small phones — single line with all items */
@media (max-width: 430px){
  .logo{height:34px}
  .tabs{gap:14px}
  .tabs .tab{font-size:12.5px;padding:6px 0}
  .tabs .tab::after{height:2px;bottom:2px;width:60%}
  .btn.cta{padding:8px 10px;font-size:12px}
  .header-wrap{padding:8px 12px}
}

/* ===========================
   Hero
=========================== */
.hero{position:relative;min-height:60vh;display:grid;place-items:center;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:calc(50% + var(--hero-shift-x)) center;filter:brightness(.55)}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 45%,rgba(0,0,0,.16) 0%,rgba(0,0,0,.55) 55%,rgba(0,0,0,.78) 100%)}
.hero-inner{position:relative;z-index:2;width:min(var(--wrap),92%);margin-inline:auto}
.hero-pill{
  display:inline-flex;align-items:center;gap:clamp(17px,2.12vw,23.5px);
  background:rgba(255,255,255,.07);
  border:3.76px solid rgba(255,255,255,.80);border-radius:24.8px;
  padding:clamp(16.8px,1.77vw,21.2px) clamp(21.2px,2.71vw,33px);
  backdrop-filter:blur(6px);box-shadow:0 16px 44px rgba(0,0,0,.42);
  margin:0 auto clamp(11.8px,1.53vw,18.8px)
}
.pill-dog{height:clamp(54.1px,6.36vw,77.7px);width:auto}
.pill-word{font-family:var(--brand-font);font-weight:700;letter-spacing:.02em;font-size:clamp(36.5px,5.41vw,65.9px);line-height:1}
.pill-navy{color:var(--navy)}.pill-orange{color:var(--orange)}
.hero h1{font-family:var(--brand-font);color:#fff;font-weight:700;font-size:clamp(25px,3.45vw,39px);margin:10px 0 6px;letter-spacing:.02em}
.hero .strap{color:#d7e6ff;font-weight:700;letter-spacing:.22em;font-family:var(--brand-font);font-size:clamp(15px,1.6vw,21px)}

/* ===========================
   Services
=========================== */
.services{
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-900) 100%);
  padding:32px 0 26px;border-top:1px solid rgba(255,255,255,.06)
}
.services-wrap{max-width:var(--wrap);margin-inline:auto;padding:0 var(--pad-x)}
.section-title{
  font-family:var(--brand-font);text-align:center;color:#fff;margin:0 0 14px;
  letter-spacing:.08em;font-size:clamp(20px,2.6vw,28px)
}
.section-title::after{content:"";display:block;width:90px;height:6px;border-radius:3px;background:var(--orange);margin:8px auto 0}

/* Keep 2x2 grid even on phones */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-items:stretch}
@media (max-width: 420px){.cards{gap:10px}}

.card{
  height:100%;display:flex;flex-direction:column;background:#0c2548;
  border:2px solid var(--orange);border-radius:16px;overflow:hidden;color:#eff3ff;
  box-shadow:0 10px 26px rgba(0,0,0,.28)
}
.card-media img{display:block;width:100%;height:150px;object-fit:cover;filter:contrast(.98) saturate(.96)}
@media (max-width:420px){.card-media img{height:120px}}
.card-body{padding:10px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-family:var(--brand-font);margin:2px 0 6px;font-size:20px;letter-spacing:.02em}
.card-body p{margin:0;color:#cbd9f8;font-size:13.5px;line-height:1.35}
.desc-gap{height:6px}
.card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}
.btn.pill{
  display:inline-flex;align-items:center;justify-content:center;
  height:30px;padding:0 12px;border-radius:999px;
  font-family:var(--brand-font);font-weight:700;letter-spacing:.04em;font-size:13.5px;
  border:2px solid var(--orange)
}
.btn.pill.primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn.pill.primary:hover{filter:brightness(.95)}
.btn.pill.ghost{background:transparent;color:var(--orange);border-color:var(--orange)}
.btn.pill.ghost:hover{background:rgba(255,122,0,.12)}

/* ===========================
   Booking
=========================== */
.booking{padding:28px 0 32px;background:linear-gradient(180deg,var(--navy-900) 0%,#081326 100%)}
.booking-wrap{max-width:var(--wrap);margin-inline:auto;padding:0 var(--pad-x)}
.booking .section-title{margin-bottom:10px}
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:900px){.booking-grid{grid-template-columns:1fr}}
.booking-panel{border:2px solid rgba(255,255,255,.95);border-radius:22px;padding:12px;background:rgba(255,255,255,0.02)}
.field{display:block}

.booking label{
  display:block;color:#e7efff;font-weight:700;text-transform:uppercase;
  font-size:12px;letter-spacing:.06em;margin:8px 0 6px
}
.booking input[type="text"],
.booking input[type="email"],
.booking input[type="tel"],
.booking input[type="date"],
.booking input[type="time"],
.booking select,
.booking textarea{
  width:100%;background:#0f2649;color:#eaf0ff;
  border:1.5px solid rgba(255,255,255,.15);border-radius:10px;
  padding:8px 10px;outline:none;font-size:var(--form-font)
}
.booking .hint{color:#9fb3d9;font-size:10px;margin-top:4px;display:block}
.booking textarea{min-height:100px;resize:vertical}
.booking .row{display:none}
.row-3b-block{display:block}

/* Site conditions */
.conditions.list{border:1px solid rgba(255,255,255,.15);padding:10px;border-radius:10px;margin:10px 0;color:#dfe9ff}
.conditions.list legend{display:block;padding:0 4px;color:#fff;font-weight:800;letter-spacing:.06em;margin-bottom:4px;font-size:var(--form-font)}
.conditions.list ul{margin:6px 0 4px 16px;padding:0}
.conditions.list li{margin:3px 0;font-size:var(--bullet-font);line-height:1.35}
.muted{color:#9fb3d9;font-size:var(--notice-font);margin-top:4px;line-height:1.4}

/* ===========================
   Contact
=========================== */
.contact{background:linear-gradient(180deg,#081326 0%, #081326 100%);padding:34px 0}
.contact-wrap{max-width:var(--wrap);margin-inline:auto;padding:0 var(--pad-x)}
.contact .section-title{margin-bottom:10px}
.contact-lead{max-width:800px;margin:0 auto 8px;color:#dbe6ff;font-size:15px;line-height:1.5;text-align:center}
.contact-lines{max-width:800px;margin:0 auto;text-align:center}
.contact-lines p{margin:6px 0;color:#e7eeff;font-size:16px}
.contact-primary{font-size:clamp(18px,2.6vw,28px)}
.contact a{color:#fff;text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.35)}
.contact a:hover{border-bottom-color:#fff}

/* ===========================
   Footer & anchor
=========================== */
.footer{color:#b8c7e8;text-align:center;padding:20px 12px}
section{scroll-margin-top:84px}

/* ===========================
   BOOK NOW width fix (no stretching)
=========================== */
.header-wrap .btn.cta{
  display:inline-flex;align-items:center;justify-content:center;
  width:auto;min-width:0;flex:0 0 auto;white-space:nowrap;
  padding:10px 14px
}
.header-wrap .tabs{
  flex:1 1 auto;min-width:0 /* center absorbs space; button stays compact */
}
@media (max-width:560px){
  .header-wrap{padding:8px 12px}
  .header-wrap .btn.cta{
    padding:8px 12px;font-size:12px;max-width:130px
  }
  .header-wrap .tabs{gap:12px}
  .header-wrap .tabs .tab{font-size:12.5px;padding:6px 0}
}
