/* Staycateer - pixel-approx vanilla CSS (sampled colors from screenshots) */
/* Sampled primary blue: #153A6A, accent dark: #0F2340 */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;500;700&family=Playfair+Display:wght@400;700&display=swap');

:root{
  --primary:#153A6A;
  --primary-dark:#0F2340;
  --muted:#6b6b6b;
  --accent:#F5F7FB;
}

*{box-sizing:border-box}
body{margin:0;font-family: "Montserrat", Arial, Helvetica, sans-serif;color:#222;line-height:1.55;background:#fff;}
a{color:var(--primary);text-decoration:none}
.header-wrap{display:flex;align-items:center;justify-content:space-between;padding:28px 6% 20px 6%;border-bottom:1px solid #e6e6e6}
.logo img{height:72px;display:block}
.nav{display:flex;gap:26px;align-items:center}
.nav a{padding:10px 6px;color:var(--primary);font-weight:500;position:relative}
.nav a.active{background:#9fb5d3; color:var(--primary-dark);padding:14px 18px;border-radius:3px;box-shadow:none;}
.nav a.active::after{content:'';position:absolute;left:50%;transform:translateX(-50%);bottom:-16px;border:8px solid transparent;border-top-color:var(--primary-dark);}

/* HERO */
.hero{position:relative;height:520px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}
.hero-overlay{position:relative;text-align:center;color:#fff;max-width:980px;padding:0 20px}
.hero-title{font-family:"Playfair Display", serif;font-size:48px;letter-spacing:1px;background:#ffffff;padding:6px 18px;color:var(--primary);display:inline-block;font-weight:700}
.hero-sub{margin-top:28px;font-size:18px;color:#e9f0f6;max-width:680px;margin-left:auto;margin-right:auto}

/* call to action */
.btn-pill{display:inline-block;margin-top:36px;background:var(--primary);color:#fff;padding:14px 34px;border-radius:36px;font-weight:600;text-decoration:none;box-shadow:none}

/* Pill-style button fix */
.btn-pill {
  display: inline-block;
  background: var(--primary);
  color: #fff;
  padding: 14px 34px;
  border-radius: 36px;
  font-weight: 600;
  text-decoration: none;
  box-shadow: none;
  white-space: nowrap;
  width: auto;              /* ensures the button fits its text */
  max-width: fit-content;   /* prevents stretching in flexbox */
  align-self: flex-start;   /* keeps it aligned nicely in the section */
  text-align: center;
  transition: all 0.25s ease;
}

.btn-pill:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
}

.btn-pill:active {
  transform: translateY(0);
}

/* White variant of the pill button */
.btn-pill2{display:inline-block;margin-top:36px;background:#fff;color:var(--primary);padding:14px 34px;border-radius:36px;font-weight:600;text-decoration:none;box-shadow:none}

.btn-pill2 {
  display: inline-block;
  background: #fff;
  color: var(--primary);
  padding: 14px 34px;
  border-radius: 36px;
  font-weight: 600;
  text-decoration: none;
  border: 2px solid var(--primary);
  box-shadow: none;
  white-space: nowrap;
  width: auto;
  max-width: fit-content;
  align-self: flex-start;
  text-align: center;
  transition: all 0.25s ease;
  font-family: "Montserrat", sans-serif;
}

.btn-pill2:hover {
  background: #fff;
  transform: translateY(-2px);
}

.btn-pill2:active {
  transform: translateY(0);
}

/* Main two-column */
.section{display:flex;align-items:stretch;gap:40px;padding:80px 6%}
.section .left{flex:1}
.section .right{flex:1;display:flex;flex-direction:column;justify-content:center}
.h2{font-family:"Playfair Display", serif;font-size:44px;color:var(--primary-dark);margin:0 0 22px 0}
.lead{color:var(--muted);max-width:520px}

/* Footer logo and contact right */
.footer{display:flex;align-items:center;justify-content:space-between;padding:44px 6%;border-top:1px solid #eee}
.footer .logo{height:74px}

/* FAQ hero blue overlay style */
.faq-hero{background:var(--primary);color:#fff;padding:64px 6%;text-align:center}
.faq-hero h1{font-family:"Playfair Display", serif;font-size:42px;margin:0;padding:4px 8px;background:#fff;color:var(--primary);display:inline-block}

/* FAQ page heading alignment fix */
.faq-hero {
  background: var(--primary);
  color: #fff;
  padding: 80px 6%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.faq-heading h1 {
  font-family: "Playfair Display", serif;
  font-size: 42px;
  margin: 0;
  padding: 8px 16px;
  background: #fff;
  color: var(--primary);
  display: inline-block;
  border-radius: 4px;
}

.faq-heading p {
  margin-top: 16px;
  color: #fff;
  background: rgba(0, 0, 0, 0.35);
  padding: 10px 16px;
  border-radius: 4px;
  max-width: 640px;
  font-size: 17px;
  line-height: 1.5;
}

/* Contact page form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid .full{grid-column:1/-1}
input, textarea{border:0;border-bottom:2px solid #ddd;padding:12px 10px;font-size:15px;background:#f6f6f6}
textarea{min-height:140px;resize:vertical}

/* Contact page layout fix */
.contact-section {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 60px;
  padding: 80px 6%;
  flex-wrap: wrap;
}

.contact-image img {
  width: 100%;
  max-width: 520px;
  border-radius: 6px;
  display: block;
}

.contact-form {
  flex: 1;
  max-width: 540px;
  min-width: 320px;
}

.contact-form form {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.contact-form label {
  display: block;
  font-weight: 500;
  color: var(--primary-dark);
  margin-bottom: 6px;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 12px 10px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background: #f8f8f8;
}

.contact-form textarea {
  min-height: 160px;
}

.contact-form button {
  align-self: flex-start;
  margin-top: 8px;
}

/* Inline message beside submit button */
.form-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
  flex-wrap: wrap;
}

/* Contact form status message */
.form-status {
  display: inline-block;
  margin-bottom: 18px;
  padding: 14px 20px;
  border-radius: 6px;
  font-weight: 500;
  font-size: 15px;
  opacity: 0;
  animation: fadeIn 0.5s ease forwards;
}

.form-status.success {
  background-color: #e6f9ef;
  color: #1b7d3a;
  border: 1px solid #b8e3c5;
}

.form-status.error {
  background-color: #fdeaea;
  color: #a94442;
  border: 1px solid #f5c6cb;
}

.form-status.invalid {
  background-color: #fff3cd;
  color: #856404;
  border: 1px solid #ffeeba;
}

@keyframes fadeIn {
  to { opacity: 1; }
}

/* responsive */
@media (max-width:900px){
  .section{flex-direction:column;padding:40px 6%}
  .hero{height:420px}
  .hero-title{font-size:34px}
  .h2{font-size:34px}
}

@media (max-width:600px){
  .header-wrap{padding:18px 5%}
  .logo img{height:56px}
  .nav{gap:14px}
  .hero{height:360px}
  .hero-title{font-size:26px}
  .section{padding:28px 5%}
  .form-grid{grid-template-columns:1fr}
  .footer{flex-direction:column;gap:18px;text-align:center}
}
