/* Main stylesheet with responsive mobile menu and compact header */

:root {
  --green-dark: #1B4636;
  --green-light: #2F7A59;
  --gold-accent: #F6A545;
  --beige-bg: #FFF9F1;
  --white: #FFFFFF;
  --shadow-main: 0 6px 40px rgba(18, 46, 36, 0.12);
  --text-main: #1F332B;
  --text-second: #4A5A52;
  --header-height: 82px;
  --focus-outline: #C09371;
  --radius-lg: 18px;
  --radius-sm: 6px;
  --font-heading: 'Poppins',sans-serif;
  --font-body: 'Inter',sans-serif;
}

html {
  font-size: 16px;
  background: var(--beige-bg);
  color: var(--text-main);
  font-family: var(--font-body);
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-height);
}
body { line-height: 1.7; margin:0; }

body.maintenance-active {
  overflow: hidden;
}

body.maintenance-active > *:not(.maintenance-overlay) {
  filter: blur(2px);
  pointer-events: none !important;
  user-select: none;
}

.maintenance-overlay {
  position: fixed;
  inset: 0;
  background: rgba(27, 70, 54, 0.92);
  color: var(--white);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  text-align: center;
  z-index: 2200;
}

.maintenance-overlay.visible {
  display: flex;
}

.maintenance-overlay__content {
  max-width: 540px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-lg);
  padding: 2.4rem 2rem;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(6px);
}

.maintenance-overlay__content h1 {
  color: var(--white);
  margin-bottom: 1rem;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
}

.maintenance-overlay__content p {
  color: var(--white);
  font-size: 1.05rem;
  line-height: 1.6;
}

h1,h2,h3,h4 {
  font-family: var(--font-heading);
  color: var(--green-dark);
  font-weight: 700;
  letter-spacing: 0.01em;
  margin-top:0;
}
h1 { font-size: clamp(2.6rem,5vw,3.7rem); line-height: 1.1; }
h2 { font-size: clamp(2.2rem,4vw,2.7rem); text-align:center; margin-bottom:.7rem;}
h3 { font-size:1.35rem;margin-bottom:.2rem;}
h4 { font-size:1.08rem; color:var(--green-light); font-weight:500; text-transform:uppercase; letter-spacing:1px; margin-bottom:.7rem;}
p { color: var(--text-second); margin-bottom: 1rem; }
a { color: var(--gold-accent); text-decoration: none; font-weight: 600; transition: color .2s;}
a:hover,a:focus { color: var(--green-dark); text-decoration: underline; }
img, picture, .responsive-image { display:block; max-width:100%; height:auto; border:none; }

.container { max-width:1200px; margin:0 auto; padding:0 1.7rem; }

.site-header {
  position:fixed; top:0; left:0; width:100%; height:var(--header-height); z-index:2100;
  background:rgba(255,255,255,.94); box-shadow:0 1.5px 8px rgba(27,70,54,0.08);
  display:flex; align-items:center; transition:background .4s,box-shadow .4s; overflow:visible;
}

.site-header.scrolled {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 10px 35px rgba(27,70,54,0.14);
  backdrop-filter: blur(6px);
}

.header-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
  position: relative;
  gap: 1rem;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 1.1rem;
}

.logo img {
  width: 120px;
  min-width: 72px;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
.logo { display: flex; flex-shrink: 0; align-items: center; margin-right:2.2rem; font-size: 1.7rem; }

.navbar {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
}

.nav-links {
  display: flex; gap:2.1rem; align-items:center;
  list-style:none; background:none; position:static; box-shadow:none; padding:0; margin:0;
}
.nav-links li { margin:0; }
.nav-links a {
  font-size:1.18rem; color:var(--green-dark); padding:0.2rem 0.5rem;
  border-radius: var(--radius-sm); font-weight: 700;
  transition: color .17s, background .17s;
}
.nav-links a:hover, .nav-links a:focus {
  color:var(--gold-accent); background:rgba(246,165,69,0.14);
  outline:none;
}

.cta-button {
  background: var(--gold-accent);
  color: var(--green-dark);
  padding: 0.78rem 2.2rem;
  border-radius: 50px;
  font-family: var(--font-heading);
  font-weight: 700;
  border: 2.5px solid var(--gold-accent);
  cursor: pointer;
  transition: background .23s, color .23s, border .23s, box-shadow .2s;
  font-size: 1.15rem;
  letter-spacing: 0.01em;
  margin-left: 1.7rem;
  box-shadow: 0 2.5px 18px rgba(246,165,69,.18);
  outline: none;
}
.cta-button:hover, .cta-button:focus {
  background: transparent;
  color: var(--gold-accent);
  border: 2.5px solid var(--gold-accent);
  box-shadow:0 8px 22px rgba(246,165,69,0.28);
  text-decoration: underline;
}

.lang-switch {
  background:transparent; border:2px solid var(--green-dark);
  color:var(--green-dark); padding:0.53rem 1.25rem;
  border-radius:12px; font-weight:700; cursor:pointer;
  font-size:1rem; transition:background .2s, color .2s, border .2s;
  margin-left: 1.2rem;
}
.lang-switch:hover, .lang-switch:focus {
  background:var(--green-dark); color:var(--white); border-color:var(--green-dark);
}

.hamburger {
  display:none; flex-direction:column; justify-content:space-between;
  width:30px; height:21px; background:transparent; border:none; cursor:pointer;
  margin-left:1.2rem; padding:0;
}
.hamburger span {
  height:3px; width:100%; background:var(--green-dark); border-radius:2px; display:block; transition:all .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(9px) rotate(45deg);}
.hamburger.open span:nth-child(2) { opacity:0;}
.hamburger.open span:nth-child(3) { transform:translateY(-9px) rotate(-45deg);}

@media (max-width:1050px) {
  .nav-links { gap:1.3rem; }
}

@media (max-width: 992px) {
  nav.navbar { flex: 0 0 auto; }
  .logo img { width: 100px; }
  .cta-button { padding: 0.5rem 1.4rem; font-size: 0.95rem; }

  .hamburger { display:flex; }
  .nav-links {
    display: none;
    position: fixed;
    top: var(--header-height);
    right: 0;
    left: 0;
    height: calc(100vh - var(--header-height));
    width: 100%;
    background: var(--beige-bg);
    flex-direction: column;
    padding: 1.5rem 1rem;
    box-shadow: 0 6px 40px rgba(0,0,0,0.18);
    overflow-y: auto;
    gap: 1.5rem;
    align-items: center;
    z-index: 9999;
    transition: transform 0.3s ease, opacity 0.3s ease;
    transform: translateY(-10px);
    opacity: 0;
    pointer-events: none;
  }
  .nav-links.open {
    display: flex;
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
}

@media (min-width: 993px) {
  .nav-links { display: flex !important; }
  .hamburger { display: none !important; }
}

/* === Hero / Carousel === */
#hero {
 position:relative;
 width:100vw;
 height:80vh;
 min-height:400px;
 overflow:hidden;
 background: var(--beige-bg);
 margin-top: var(--header-height);
 padding: 0;
}
.carousel-wrapper {
 position: relative;
 width: 100vw;
 height: 80vh;
 min-height:400px;
 overflow: hidden;
 margin: 0 auto;
 background: var(--beige-bg);
}
.carousel-slide {
 position:absolute;
 top:0; left:0;
 width:100vw;
 height: 80vh;
 min-height: 400px;
 object-fit: cover;
 opacity:0;
 z-index: 1;
 transition: opacity 1.1s, transform 6.5s;
 transform:scale(1.04);
}
.carousel-slide.active {
 opacity:1;
 z-index:2;
 transform: scale(1);
}
.carousel-wrapper::after {
  content:"";
  position:absolute; top:0; left:0; width:100vw; height:100%;
  background:linear-gradient(93deg,rgba(27,70,54,0.28) 0%,rgba(246,165,69,0.08) 100%);
  z-index:3; pointer-events:none;
}

.carousel-content {
 position: absolute;
 top: 50%; left: 50%;
 transform: translate(-50%, -50%);
 z-index: 12;
 width: 100%;
 max-width: 940px;
 padding: 0 2rem;
 text-align: center;
 color: #fff;
  pointer-events: auto;
}
.carousel-content h1 {
 color: #fff;
 margin-bottom: 1.1rem;
 text-shadow: 0 3px 30px rgba(0,0,0,0.15);
}
.carousel-content p {
 color: #fff;
 font-size: 1.22rem;
 text-shadow: 0 3px 18px rgba(0,0,0,0.12);
 max-width: 800px;
 margin: 0 auto;
}

/* Carousel Controls */
.carousel-controls {
 position: absolute;
 bottom: 40px;
 left: 0; right: 0;
 width: 100vw;
 display: flex;
 align-items: center;
 justify-content: center;
 gap: 1.5rem;
 z-index: 22;
 pointer-events: none;
}
.carousel-arrow {
  background: rgba(255,255,255,0.88);
  border: 2.5px solid rgba(27,70,54,0.45);
 width: 48px; height: 48px;
 border-radius: 50%;
 color: var(--green-dark);
 font-size: 2.1rem;
 cursor: pointer;
 opacity: 0.85;
 box-shadow: 0 2px 18px rgba(0,0,0,0.09);
 pointer-events: auto;
 transition: background .21s, border .21s, color .19s;
 display: flex; align-items: center; justify-content: center;
}
.carousel-arrow:hover, .carousel-arrow:focus {
  background: var(--gold-accent);
  color: var(--white);
  border-color: var(--gold-accent);
}
.carousel-dots {
 display: flex;
 gap: 14px;
 align-items: center;
 justify-content: center;
 z-index: 25;
 pointer-events: auto;
}
.carousel-dot {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: rgba(27,70,54,0.26);
  border: none; outline: none;
  cursor: pointer;
  transition: background .34s, box-shadow .28s, transform .25s;
}
.carousel-dot.active {
  background: var(--gold-accent);
  transform: scale(1.24);
  box-shadow: 0 0 0 6px rgba(246,165,69,0.2);
}

/* Remove any bottom bands */
#hero, .carousel-wrapper, .carousel-slide {
 box-shadow: none;
 border: none;
 background: none;
}

/* Responsive hero + carousel */
@media (max-width: 900px) {
 #hero, .carousel-wrapper, .carousel-slide {
  height: 380px;
  min-height: 260px;
 }
 .carousel-content {
  max-width: 96vw;
  padding: 0 0.8rem;
 }
 .carousel-controls {
  bottom: 20px;
 }
}
@media (max-width: 650px) {
 #hero, .carousel-wrapper, .carousel-slide {
  height: 270px; min-height: 170px;
 }
 .carousel-content {
    top: 40%;
    transform: translate(-50%, -40%);
    padding: 0 0.8rem 70px;
    max-height: calc(100% - 80px);
    overflow-y: auto;
 }
 .carousel-content h1 {
  font-size: 2.1rem;
 }
 .carousel-content p {
  font-size: 1.07rem;
 }
 .carousel-arrow { width: 38px; height: 38px; font-size: 1.3rem; }
 .carousel-dot { width: 12px; height: 12px; }
 .carousel-controls {
    bottom: 20px;
 }
}

/* === Sections & Grids === */
section { padding:3.6rem 0 3.5rem 0;}
.bg-light { background-color:var(--beige-bg);}
.section-subtitle {
 display:block; text-align:center; color:var(--green-light);
 font-family:var(--font-heading); font-weight:500;
 margin-bottom:2.1rem; font-size:1.12rem;
 letter-spacing:0.03em;
}

/* Services Grid */
.services-grid {
 display:grid; grid-template-columns:repeat(auto-fit,minmax(295px,1fr)); gap:2.1rem;
 margin-top:1.2rem; justify-items:center;
}
.service-card {
 background:var(--white); padding:2.4rem 1.2rem 2.2rem 1.2rem; border-radius:var(--radius-lg);
 box-shadow:var(--shadow-main);
 transition:transform 0.24s, box-shadow 0.25s;
 display:flex; flex-direction:column; align-items:center;
 min-width:0; min-height:285px;
}
.service-card:hover { transform:translateY(-8px) scale(1.02); box-shadow:0 14px 44px rgba(27,70,54,0.18);}
.service-icon {
  width:63px; height:63px; border-radius:50%; background:var(--beige-bg);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:1.6rem; box-shadow:0 0 0 2px var(--gold-accent);
  font-size:2.2rem;
}

/* === Team === */
.team-grid {
 display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:2.6rem; align-items:center;
 margin-top:2rem;
}
.team-member {
  display:flex; align-items:center; gap:1.3rem;
  background:rgba(255,255,255,0.94); border-radius:var(--radius-lg); padding:1.3rem 1rem;
  box-shadow:0 2px 18px rgba(27,70,54,0.14);
  transition:box-shadow 0.18s;
}
.team-member:hover { box-shadow:0 12px 32px rgba(27,70,54,0.16);}
.team-member img {
  width:120px; height:120px; border-radius:50%; object-fit:cover;
  border:4px solid var(--gold-accent); box-shadow:0 5px 18px rgba(27,70,54,0.16);
}
@media (max-width:700px) {
 .team-grid { grid-template-columns:1fr; }
 .team-member { flex-direction:column; text-align:center; gap:0.8rem;}
}

/* === Contact & Footer === */
.contact-section { background-color:var(--beige-bg); color:var(--green-dark);}
.contact-section h2, .contact-section .section-subtitle { color:var(--green-dark);}
.contact-content { text-align:center; max-width:680px; margin:0 auto;}
.contact-content p { color:var(--text-main); }
.contact-details {
 margin-top:2.1rem; font-size:1.22rem; line-height:1.9; font-family:var(--font-heading);
}
.contact-details a { color:var(--gold-accent); }
.contact-details a:focus { color:var(--white); background:var(--gold-accent); border-radius:5px; }

.site-footer { background-color:var(--beige-bg); padding:3.3rem 0 1.7rem 0;}
.footer-grid {
 display:grid; grid-template-columns:2fr 1fr 1fr 1.3fr; gap:2.3rem;
}
.footer-grid h4 {
 font-size:1.01rem; text-transform:uppercase; letter-spacing:1px; margin-bottom:1rem;
}
.footer-grid ul { list-style:none; margin:0; padding:0;}
.footer-grid li { margin-bottom:0.5rem;}
.footer-grid a { color:var(--text-second); font-weight:500;}
.footer-grid a:hover,.footer-grid a:focus { color:var(--gold-accent); }
.footer-bottom {
  border-top:1px solid rgba(27,70,54,0.14); margin-top:2.2rem; padding-top:1.5rem;
  display:flex; justify-content:space-between; align-items:center;
  font-size:0.95rem; color:#4A5A52;
}

@media (max-width:1100px) {
 .container { max-width:96vw; }
 .footer-grid { grid-template-columns:1.5fr 1fr 1fr;}
}
@media (max-width:900px) {
 .footer-grid { grid-template-columns:1fr 1fr; gap:1.3rem;}
}
@media (max-width:700px) {
 section { padding:2.1rem 0;}
 .footer-grid { grid-template-columns:1fr; text-align:center;}
 .footer-bottom { flex-direction:column; gap:0.6rem;}
}

/* Fade-in animation */
.fade-in { opacity:0; transform:translateY(32px); transition:opacity .78s, transform .78s;}
.fade-in.visible { opacity:1; transform:translateY(0);}

@media (max-width: 600px) {
  .cta-button {
    display: none;
  }
}

/* Cookie banner */
.cookie-banner {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  left: 1.5rem;
  max-width: 460px;
  margin: 0 auto;
  z-index: 4000;
  background: var(--white);
  color: var(--text-main);
  border-radius: var(--radius-lg);
  box-shadow: 0 18px 46px rgba(27,70,54,0.18);
  padding: 1.6rem;
  display: none;
  gap: 1.1rem;
}

.cookie-banner.visible {
  display: grid;
}

.cookie-banner h3 {
  font-size: 1.25rem;
  margin-bottom: 0.4rem;
}

.cookie-banner p {
  margin: 0;
}

.cookie-actions {
  display: flex;
  gap: 0.8rem;
  margin-top: 1.2rem;
  flex-wrap: wrap;
}

.btn {
  border-radius: 999px;
  padding: 0.55rem 1.6rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, color .2s, border .2s, box-shadow .2s;
  border: 2px solid transparent;
  font-family: var(--font-heading);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-primary {
  background: var(--green-dark);
  color: var(--white);
  border-color: var(--green-dark);
  box-shadow: 0 10px 25px rgba(27,70,54,0.22);
}

.btn-primary:hover,
.btn-primary:focus {
  background: transparent;
  color: var(--green-dark);
  border-color: var(--green-dark);
}

.btn-secondary {
  background: transparent;
  color: var(--green-dark);
  border-color: rgba(27,70,54,0.32);
}

.btn-secondary:hover,
.btn-secondary:focus {
  background: rgba(27,70,54,0.08);
  color: var(--green-dark);
}

.cookie-banner a {
  color: var(--gold-accent);
  text-decoration: underline;
  font-weight: 600;
}

@media (max-width: 520px) {
  .cookie-banner {
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    padding: 1.3rem;
  }
  .cookie-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .btn {
    width: 100%;
    text-align: center;
  }
}