/* FINAL CLEAN HEADER — loaded after all old CSS */

.topbar{
  position:sticky !important;
  top:0 !important;
  z-index:999999 !important;
  background:#fff !important;
  border-bottom:1px solid #eadfce !important;
  box-shadow:0 8px 24px rgba(21,28,36,.05) !important;
}

.topbar *{
  box-sizing:border-box !important;
}

.topbar .nav{
  max-width:1220px !important;
  margin:0 auto !important;
  height:74px !important;
  padding:0 22px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:24px !important;
}

.topbar .brand{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  flex:0 0 250px !important;
  width:250px !important;
  max-width:250px !important;
  min-width:250px !important;
  overflow:visible !important;
  text-decoration:none !important;
}

.topbar .brand-logo-img{
  display:block !important;
  width:240px !important;
  max-width:240px !important;
  height:auto !important;
  visibility:visible !important;
  opacity:1 !important;
}

.topbar .main-menu{
  display:flex !important;
  flex:1 1 auto !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:14px !important;
  width:auto !important;
  max-width:none !important;
  height:74px !important;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}

.topbar .main-menu a{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:40px !important;
  min-height:40px !important;
  padding:0 !important;
  margin:0 !important;
  border:0 !important;
  background:transparent !important;
  color:#47515d !important;
  font-size:13px !important;
  line-height:1 !important;
  font-weight:900 !important;
  text-decoration:none !important;
  white-space:nowrap !important;
}

.topbar .main-menu .work{
  color:#7a552a !important;
}

.topbar .main-menu .cta{
  background:#151c24 !important;
  color:#fff !important;
  border:1px solid #151c24 !important;
  padding:0 15px !important;
}

/* Kill all old extra menus/buttons */
.topbar .desktop-menu,
.topbar .mobile-required-menu,
.topbar .mobile-group-menu,
.topbar .site-menu,
.topbar .mobile-menu-btn{
  display:none !important;
}

/* But if the single menu also has menu class, keep it visible */
.topbar .main-menu.menu{
  display:flex !important;
}

/* Tablet safety */
@media(min-width:901px) and (max-width:1120px){
  .topbar .nav{
    padding:0 14px !important;
    gap:12px !important;
  }

  .topbar .brand{
    flex-basis:205px !important;
    width:205px !important;
    max-width:205px !important;
    min-width:205px !important;
  }

  .topbar .brand-logo-img{
    width:198px !important;
    max-width:198px !important;
  }

  .topbar .main-menu{
    gap:9px !important;
  }

  .topbar .main-menu a{
    font-size:12px !important;
  }

  .topbar .main-menu .cta{
    padding:0 10px !important;
  }
}

/* Mobile: logo top, menu 2 rows, no duplicate */
@media(max-width:900px){
  .topbar{
    overflow:visible !important;
  }

  .topbar .nav{
    height:auto !important;
    min-height:0 !important;
    width:100% !important;
    max-width:none !important;
    padding:9px 10px 10px !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    align-items:start !important;
    justify-content:start !important;
    gap:8px !important;
  }

  .topbar .brand{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    flex:none !important;
    justify-content:flex-start !important;
  }

  .topbar .brand-logo-img{
    width:220px !important;
    max-width:80vw !important;
    height:auto !important;
  }

  .topbar .main-menu{
    display:grid !important;
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    grid-template-columns:repeat(6, 1fr) !important;
    grid-template-areas:
      "home home price price guide guide"
      "jobs jobs jobs calc calc calc" !important;
    gap:6px !important;
    padding:0 !important;
    margin:0 !important;
    overflow:visible !important;
  }

  .topbar .main-menu a{
    display:flex !important;
    height:34px !important;
    min-height:34px !important;
    padding:0 4px !important;
    border:1px solid #eadfce !important;
    background:#fff !important;
    color:#151c24 !important;
    font-size:12px !important;
    line-height:1 !important;
    font-weight:900 !important;
    text-decoration:none !important;
    white-space:nowrap !important;
  }

  .topbar .main-menu .m-home{ grid-area:home !important; }
  .topbar .main-menu .m-price{ grid-area:price !important; }
  .topbar .main-menu .m-guide{ grid-area:guide !important; }
  .topbar .main-menu .work{ grid-area:jobs !important; }
  .topbar .main-menu .cta{ grid-area:calc !important; }

  .topbar .main-menu .mobile-hide{
    display:none !important;
  }

  .topbar .main-menu .work{
    background:#fff8ed !important;
    color:#7a552a !important;
    border-color:#e6d8c6 !important;
  }

  .topbar .main-menu .cta{
    background:#151c24 !important;
    color:#fff !important;
    border-color:#151c24 !important;
  }
}

@media(max-width:370px){
  .topbar .brand-logo-img{
    width:205px !important;
    max-width:78vw !important;
  }

  .topbar .main-menu{
    gap:5px !important;
  }

  .topbar .main-menu a{
    font-size:11px !important;
    padding:0 2px !important;
  }
}

/* === FIX: mobile menu required links visible === */
@media(max-width:900px){

  .topbar .main-menu{
    display:grid !important;
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    min-height:0 !important;
    grid-template-columns:repeat(6, 1fr) !important;
    grid-template-areas:
      "home home price price guide guide"
      "jobs jobs jobs calc calc calc" !important;
    gap:6px !important;
    padding:0 !important;
    margin:0 !important;
    overflow:visible !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
  }

  .topbar .main-menu a{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    align-items:center !important;
    justify-content:center !important;
    height:34px !important;
    min-height:34px !important;
    padding:0 4px !important;
    margin:0 !important;
    border:1px solid #eadfce !important;
    background:#fff !important;
    color:#151c24 !important;
    -webkit-text-fill-color:#151c24 !important;
    font-size:12px !important;
    line-height:1 !important;
    font-weight:900 !important;
    text-align:center !important;
    text-decoration:none !important;
    white-space:nowrap !important;
    overflow:hidden !important;
  }

  .topbar .main-menu .m-home{
    grid-area:home !important;
  }

  .topbar .main-menu .m-price{
    grid-area:price !important;
  }

  .topbar .main-menu .m-guide{
    grid-area:guide !important;
  }

  .topbar .main-menu .mobile-hide{
    display:none !important;
  }

  .topbar .main-menu .work,
  .topbar .main-menu a[href="/avoimet-putkiremontti-tarjouspyynnot/"]{
    display:flex !important;
    grid-area:jobs !important;
    background:#fff8ed !important;
    color:#7a552a !important;
    -webkit-text-fill-color:#7a552a !important;
    border:1px solid #e6d8c6 !important;
  }

  .topbar .main-menu .cta,
  .topbar .main-menu a[href="/#laskuri"]{
    display:flex !important;
    grid-area:calc !important;
    background:#151c24 !important;
    color:#ffffff !important;
    -webkit-text-fill-color:#ffffff !important;
    border:1px solid #151c24 !important;
  }
}

@media(max-width:370px){
  .topbar .main-menu{
    gap:5px !important;
  }

  .topbar .main-menu a{
    height:32px !important;
    min-height:32px !important;
    font-size:11px !important;
    padding:0 2px !important;
  }
}
