:root{
      --bg:#0f1113;          /* page background for sections that need contrast */
      --paper:#ffffff;       /* content background */
      --ink:#1a1f24;         /* primary text */
      --muted:#5b6570;       /* secondary text */
      --line:#e6e9ec;        /* hairlines */
      --brand:#2f5a47;       /* deep green accent – timber inspired */
      --brand-2:#9b8c7b;     /* warm timber note */
      --grey:#f6f7f8;        /* light grey panels */
      --radius:16px;
      --shadow:0 10px 30px rgba(0,0,0,.08);
    }
    *{box-sizing:border-box}
    html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;color:var(--ink);background:var(--paper)}
    img{max-width:100%;height:auto;display:block}
    a{color:var(--brand);text-decoration:none}
    a:hover{text-decoration:underline}

    /* Header */
    .topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:saturate(130%) blur(6px);border-bottom:1px solid var(--line)}
    .wrap{max-width:1100px;margin-inline:auto;padding:0 20px}
    .nav{display:flex;align-items:center;gap:24px;padding:12px 0}
    .logo{display:flex;align-items:center;gap:12px}
    .logo img{width:44px;height:44px;border-radius:8px;object-fit:contain;background:#fff}
    .brand{font-weight:800;letter-spacing:.2px}
    .grow{flex:1}
    .menu{display:flex;gap:18px}
    .menu a{padding:8px 10px;border-radius:10px;font-weight:600;color:var(--ink)}
    .menu a:hover{background:var(--grey)}
    .cta{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;background:var(--brand);color:#fff;border:1px solid #245142;box-shadow:var(--shadow)}
    .cta:hover{opacity:.92;text-decoration:none}

    /* Hero */
    .hero{position:relative;background:#111;color:#fff}
    .hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
    .hero-copy{padding:64px 0}
    .kicker{display:inline-block;font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#c7d6cf;margin-bottom:10px}
    .hero h1{margin:0 0 14px;font-size:42px;line-height:1.1}
    .hero p{margin:0 0 22px;color:#e7eeea}
    .badge{display:inline-flex;align-items:center;gap:10px;background:#183c2f;padding:8px 12px;border-radius:999px;border:1px solid #214b3b;color:#e9f5f0;font-weight:600}
    .hero figure{overflow:hidden;border-radius:var(--radius);border:1px solid #233b31;box-shadow:0 20px 50px rgba(0,0,0,.35)}
    .hero figure img{width:100%;height:100%;object-fit:cover}

    /* Sections */
    section{padding:64px 0}
    .section-grey{background:var(--grey)}
    h2{margin:0 0 18px;font-size:28px}
    .lead{color:var(--muted);max-width:70ch}

    /* Services grid */
    .cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
    .card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
    .card h3{margin:0 0 6px}
    .card p{margin:0;color:var(--muted)}

    /* Gallery */
    .gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
    .gallery figure{margin:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
    .gallery figcaption{padding:8px 12px;background:#fff;border-top:1px solid var(--line);font-size:14px;color:var(--muted)}

    /* Quote form */
    form{display:grid;gap:14px}
    .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
    label{font-weight:600}
    input,select,textarea{width:100%;padding:12px 12px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--ink);font:inherit}
    textarea{min-height:120px}
    .hint{font-size:12px;color:var(--muted)}
    .btn{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;background:var(--brand);color:#fff;border:1px solid #244d3f;font-weight:700;cursor:pointer}
    .btn.secondary{background:#f0f2f4;color:#0b0e10;border-color:#e0e4e8}

    /* Contact */
    .contact-list{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
    .contact-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px}

    /* Footer */
    footer{padding:28px 0;border-top:1px solid var(--line);background:#fff}
    .foot{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center}
    .foot small{color:var(--muted)}

    /* Responsive */
    @media (max-width: 960px){
      .hero-inner{grid-template-columns:1fr}
      .cards{grid-template-columns:1fr 1fr}
      .contact-list{grid-template-columns:1fr}
    }
    @media (max-width: 640px){
      .menu{display:none}
      .cards,.gallery{grid-template-columns:1fr}
      .grid-2{grid-template-columns:1fr}
      .hero h1{font-size:34px}
    }


    #cookie-banner {
  position: fixed;
  bottom: -200px;
  left: 50%;
  transform: translateX(-50%);
  background: #ffffff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  padding: 20px 25px;
  border-radius: 15px;
  max-width: 400px;
  width: 90%;
  text-align: center;
  font-family: sans-serif;
  opacity: 0;
  transition: all 0.8s ease;
  z-index: 9999;
  animation: floaty 3s ease-in-out infinite;
}

#cookie-banner.show {
  bottom: 30px;
  opacity: 1;
}

#cookie-banner p {
  margin-bottom: 15px;
  font-size: 14px;
}

#cookie-banner .buttons {
  display: flex;
  justify-content: center;
  gap: 10px;
}

#cookie-banner button {
  padding: 8px 16px;
  border: none;
  background-color: #007bff;
  color: white;
  cursor: pointer;
  border-radius: 8px;
  font-size: 14px;
  transition: background-color 0.3s;
}

#cookie-banner button:hover {
  background-color: #0056b3;
}