:root{
  --bg:#0c4228;
  --gold:#d7b25a;
  --text:var(--gold);
  --muted:rgba(215,178,90,.85);
  --surface:#0f4f31;
  --surface-2:#0b3a23;
  --border:rgba(215,178,90,.22);
  --shadow:0 14px 30px rgba(0,0,0,.35);
  --radius:14px;
  --container:1100px;
}

*,
*::before,
*::after{ box-sizing:border-box; }

html:focus-within{ scroll-behavior:smooth; }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

/* Mobile/layout safety */
*{ min-width:0; }
img, video, svg, canvas{ max-width:100%; height:auto; }
body{ overflow-x:hidden; }


a{ color:inherit; }

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 1rem;
}

main.container{
  padding-top:2.25rem;
  padding-bottom:2.25rem;
}


.muted{ color:var(--muted); }

.skip-link{
  position:absolute;
  left:-9999px;
  top:.75rem;
  padding:.5rem .75rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:var(--shadow);
}
.skip-link:focus{
  left:1rem;
  outline:3px solid rgba(215,178,90,.55);
  outline-offset:2px;
}

.site-header{
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.nav{
  padding:1rem 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:.75rem;
  text-decoration:none;
  font-weight:800;
  letter-spacing:.2px;
}
.brand-logo{
  width:44px;
  height:44px;
  border-radius:999px;
  object-fit:cover;
  border:1px solid rgba(215,178,90,.4);
  box-shadow:0 8px 20px rgba(0,0,0,.35);
}
.brand-text{ font-size:1.05rem; }

.nav-links{
  flex-wrap:wrap;
  display:flex;
  align-items:center;
  gap:1.1rem;
}
.nav-links a{
  text-decoration:none;
  font-weight:700;
  padding:.35rem .55rem;
  border-radius:10px;
}
.nav-links a:hover{ background:rgba(215,178,90,.12); }
.nav-links a[aria-current="page"]{ background:rgba(215,178,90,.20); }

.hamburger{
  display:none;
  font-size:1.75rem;
  cursor:pointer;
  border:1px solid rgba(215,178,90,.35);
  background:rgba(215,178,90,.08);
  color:var(--gold);
  padding:.35rem .6rem;
  border-radius:12px;
}

.hamburger:focus-visible,
.nav-links a:focus-visible,
.btn:focus-visible,
.icon-link:focus-visible,

.hero{
  background:linear-gradient(180deg, rgba(15,79,49,.92), rgba(11,58,35,.92));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:clamp(2.5rem, 5vw, 4rem) clamp(1.25rem, 3vw, 2rem);
  text-align:center;
  box-shadow:var(--shadow);
}
.hero h1{
  font-size:clamp(2rem, 3.5vw, 2.75rem);
  margin:0 0 .75rem;
}
.hero p{
  margin:0 auto 1.25rem;
  max-width:78ch;
  color:var(--muted);
  font-size:1.05rem;
}
.actions{
  display:flex;
  gap:.75rem;
  justify-content:center;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--gold);
  color:var(--bg);
  text-decoration:none;
  border:none;
  padding:.9rem 1.4rem;
  font-size:1rem;
  border-radius:12px;
  cursor:pointer;
  font-weight:800;
}
.btn:hover{ filter:brightness(.95); }
.btn-ghost{
  background:transparent;
  color:var(--gold);
  border:1px solid rgba(215,178,90,.35);
}
.btn-ghost:hover{ background:rgba(215,178,90,.08); }

.section-title{
  margin:2rem 0 .75rem;
  font-size:1.5rem;
}
.grid{
  margin-top:1.5rem;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:1.25rem;
  padding-bottom:1.25rem;
}

.cards{
  margin-top:1.25rem;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1.25rem;
}

.card{
  background:rgba(15,79,49,.85);
  border:1px solid var(--border);
  padding:1.6rem;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card h2{
  margin:0 0 .5rem;
  font-size:1.15rem;
  overflow-wrap:anywhere;
  hyphens:auto;
}
.card p{
  margin:0;
  color:var(--muted);
  overflow-wrap:anywhere;
  hyphens:auto;
}

.two-col{
  margin-top:1.25rem;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1.25rem;
}

.list{
  margin:.5rem 0 0;
  padding-left:1.15rem;
  color:var(--muted);
}
.list li + li{ margin-top:.35rem; }

.contact-card{
  margin-top:1rem;
  background:rgba(15,79,49,.85);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.25rem 1.5rem;
  max-width:780px;
}

.contact-card a{ overflow-wrap:anywhere; }

.form{
  margin-top:1.25rem;
  display:grid;
  gap:1rem;
  max-width:780px;
}
.form-row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1rem;
}
label{
  display:grid;
  gap:.4rem;
  font-weight:700;
}
input, select, textarea{
  padding:.75rem .85rem;
  border-radius:12px;
  border:1px solid rgba(215,178,90,.35);
  background:rgba(215,178,90,.08);
  color:var(--gold);
  font:inherit;
}
textarea{ min-height:140px; resize:vertical; }
input::placeholder, textarea::placeholder{ color:rgba(215,178,90,.65); }
input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:3px solid rgba(215,178,90,.55);
  outline-offset:2px;
}

.cta-row{ margin-top:1.5rem; }

.site-footer{
  margin-top:2.5rem;
  padding:2rem 1rem;
  text-align:center;
  background:rgba(11,58,35,.80);
  border-top:1px solid var(--border);
}

.footer-inner{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 1rem;
  display:flex;
  flex-direction:column;
  gap:.9rem;
  align-items:center;
}
.social{
  display:flex;
  gap:.85rem;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}
.icon-link{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  text-decoration:none;
  padding:.4rem .65rem;
  border-radius:12px;
  border:1px solid rgba(215,178,90,.25);
  background:rgba(215,178,90,.06);
}
.icon{ width:18px; height:18px; fill:var(--gold); }

/* Slideshow */
.slideshow{
  margin-top:1.5rem;
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:rgba(15,79,49,.65);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.slides{
  padding:1rem;
}
.slide-single{
  margin:0;
}
.slide-single img{
  width:100%;
  height:min(60vh,520px);
  display:block;
  object-fit:cover;
  border-radius:calc(var(--radius) - 2px);
  border:1px solid rgba(215,178,90,.25);
}
.slide-caption{
  margin:.75rem 0 0;
  color:var(--muted);
  text-align:center;
}

.slideshow-meta{
  padding:0 1rem 1rem;
  color:var(--muted);
  display:flex;
  justify-content:center;
  gap:.75rem;
  flex-wrap:wrap;
}
/* Gallery */
.gallery{
  margin-top:1.25rem;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1rem;
}
.thumb{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  background:rgba(15,79,49,.65);
  box-shadow:var(--shadow);
}

.thumb img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio:16/9;
  object-fit:cover;
}


/* Mobile navigation */
@media (max-width: 820px){
  .hamburger{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

  .nav{
    flex-wrap:wrap;
  }

  .nav-links{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:0.25rem;
    margin-top:0.75rem;
    padding:0.75rem;
    background:rgba(215,178,90,.08);
    border:1px solid rgba(215,178,90,.25);
    border-radius:var(--radius);
  }

  .nav-links a{
    width:100%;
    text-align:center;
    padding:0.75rem 0.5rem;
    border-radius:12px;
  }

  .nav-links.show{
    display:flex;
  }

  .grid{ grid-template-columns:1fr; }
  .two-col{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
}

@media (max-width: 380px){
  .brand-text{ display:none; }
}

@media (max-width: 480px){
  .brand-text{ font-size:.95rem; }
  .btn{ width:100%; max-width:420px; }
  .slides{ padding:.75rem; }
  .slideshow-meta{ padding:0 .75rem 1rem; }
  .slide-single img{ height:min(45vh, 320px); }
  .gallery{ grid-template-columns:repeat(auto-fit, minmax(160px, 1fr)); }
}

@media (prefers-reduced-motion: reduce){
  html:focus-within{ scroll-behavior:auto; }
  .slides{ transition:none; }
}


/* SEO blocks */
.faq {
  margin-top: 1.25rem;
  display: grid;
  gap: 1rem;
}

details.card summary {
  cursor: pointer;
  font-weight: 800;
  list-style: none;
}

details.card summary::-webkit-details-marker {
  display: none;
}

details.card p {
  margin-top: 0.5rem;
}
