/* Reset & base */
:root{
  --wrap: 1140px;
  --accent: #0b2545;
  --accent-2: #111;
  --muted: #6b6b6b;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;margin:0;color:#111;background:#fff;line-height:1.45}
.wrap{max-width:var(--wrap);margin:0 auto;padding:28px}

/* HEADER */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,0.95);-webkit-backdrop-filter: saturate(1) blur(4px);backdrop-filter: saturate(1) blur(4px);border-bottom:1px solid rgba(0,0,0,0.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 18px}
.brand{font-weight:700;letter-spacing:1px;text-decoration:none;color:var(--accent)}
.nav{display:flex;gap:18px;align-items:center}
.nav a{color:#111;text-decoration:none;padding:8px 6px}
.btn{display:inline-block;padding:10px 14px;border-radius:8px;text-decoration:none}
.btn.primary{background:var(--accent);color:#fff}
.btn.ghost{background:transparent;border:1px solid rgba(0,0,0,0.08)}
.btn.inline{background:#111;color:#fff;padding:8px 12px;border-radius:6px}

/* MOBILE TOGGLE */
.mobile-toggle{display:none;background:transparent;border:0;cursor:pointer}
.mobile-toggle span{display:block;width:22px;height:2px;background:#111;margin:4px 0}

/* HERO */
.hero {
    position: relative;
    min-height: 80vh;
    height: 80vh;
    overflow: hidden;
}

.hero-img {
    position: absolute; /* ADD THIS */
    top: 0; /* ADD THIS */
    left: 0; /* ADD THIS */
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.hero-overlay {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    padding-top: 50px; /* moves content down */
    text-align: center;
    max-width: 900px;
    width: 100%;
    color: #111;
}

.hero-overlay h1,
.hero-overlay p {
    background: rgba(255,255,255,0.88);
    padding: 10px 14px;
    border-radius: 8px;
    margin-bottom: 12px;
}

.lead{font-size:1.05rem;margin:12px 0 20px;}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}


/* PANE / SECTIONS */
.pane{padding:0px 0}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
.col img{width:100%;height:auto;border-radius:8px}
.alt{background:#fafafa}

/* TESTIMONIALS */
blockquote{font-style:italic;border-left:4px solid var(--accent);padding:12px 16px;margin:10px 0;background:#fff}

/* CONTACT */
.contact-section .contact-form{max-width:720px;margin:18px auto;display:grid;gap:12px}
.contact-form label{display:block}
.contact-form input, .contact-form textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px}
.muted{color:var(--muted)}
.small{font-size:.9rem}

.form-message {
    margin: 20px auto;
    padding: 16px 18px;
    border-radius: 10px;
    max-width: 720px;
    font-size: 1rem;
}

.form-message.success {
    background: #eef8f1;
    color: #0b5f2a;
    border: 1px solid #b9e4c8;
}

/* FOOTER */
.site-footer{padding:30px 0;background:#fff;border-top:1px solid rgba(0,0,0,0.04);text-align:center}

/* FADE-IN (initial state) */
.fade-in{opacity:0;transform:translateY(18px);transition:all 600ms cubic-bezier(.2,.9,.2,1)}

/* CSS-only fallback - show after 2 seconds if JS hasn't run */
@keyframes forceFadeIn {
    to { opacity: 1; transform: translateY(0); }
}

.fade-in {
    animation: forceFadeIn 0.1s 2s forwards;
}


/* RESPONSIVE */
@media (max-width:900px){
  .grid{grid-template-columns:1fr}
  .hero-overlay{padding:28px}
  .wrap{padding:18px}
}

/* MOBILE MENU */
@media (max-width:800px){
  .nav{position:fixed;inset:60px 0 0 0;background:#fff;flex-direction:column;padding:20px;transform:translateY(-120%);transition:transform 220ms ease;gap:12px}
  .nav.open{transform:translateY(0)}
  .mobile-toggle{display:block}
}

/* BUTTON STYLES FOR OVERLAY CTA - clickable overlays */
.overlay-btn{position:relative;display:inline-block}

/* Ensure visible class overrides fade-in - Safari fix */
.fade-in.visible,
.visible {
    opacity: 1 !important;
    transform: translateY(0) !important;
    transition: all 600ms cubic-bezier(.2,.9,.2,1);
}

/* Safari/Edge fix: Ensure fade-in transitions work properly */
.pane.fade-in {
    opacity: 0;
    transform: translateY(18px);
    transition: all 600ms cubic-bezier(.2,.9,.2,1);
}

.pane.visible,
.pane.fade-in.visible {
    opacity: 1 !important;
    transform: translateY(0) !important;
}