.jb-site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(251,248,241,.58);
  backdrop-filter:saturate(170%) blur(24px);
  -webkit-backdrop-filter:saturate(170%) blur(24px);
  border-bottom:1px solid rgba(23,23,19,.12);
  box-shadow:0 10px 32px rgba(23,23,19,.06), inset 0 1px rgba(255,255,255,.45);
  color:#171713;
  font-family:Inter,system-ui,sans-serif;
}
.jb-site-header *{box-sizing:border-box}
.jb-site-header a{color:inherit;text-decoration:none}
.jb-site-header nav{
  position:static;
  top:auto;
  z-index:auto;
  background:transparent;
  color:inherit;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.jb-announcement{
  min-height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:8px 24px;
  background:linear-gradient(90deg,#c2addf,#d7c8ee);
  color:#171713;
  box-shadow:inset 0 -1px rgba(255,255,255,.16);
  text-align:center;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  line-height:1.25;
  text-transform:uppercase;
}
.jb-announcement a{
  font:inherit;
  letter-spacing:inherit;
  text-transform:inherit;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:4px;
}
.jb-nav{
  width:min(1240px,calc(100% - 48px));
  height:58px;
  margin-inline:auto;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:22px;
}
.jb-brand{
  font-size:18px;
  font-weight:600;
  letter-spacing:-.02em;
  line-height:1;
  text-align:center;
  white-space:nowrap;
}
.jb-links{
  display:flex;
  align-items:center;
  gap:28px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.jb-links--right{justify-content:flex-end}
.jb-call-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 16px;
  background:linear-gradient(90deg,#c2addf,#d7c8ee);
  border:1px solid rgba(23,23,19,.12);
  color:#171713;
  font-weight:700;
  white-space:nowrap;
}
.jb-menu-toggle{
  display:none;
  appearance:none;
  border:1px solid rgba(23,23,19,.16);
  background:rgba(245,240,231,.48);
  color:#171713;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  gap:4px;
  flex-direction:column;
  cursor:pointer;
}
.jb-menu-toggle span{
  display:block;
  width:18px;
  height:2px;
  background:currentColor;
  transition:transform .2s ease,opacity .2s ease;
}
.jb-menu-toggle[aria-expanded="true"] span:first-child{transform:translateY(6px) rotate(45deg)}
.jb-menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.jb-menu-toggle[aria-expanded="true"] span:last-child{transform:translateY(-6px) rotate(-45deg)}
.jb-mobile-menu{display:none}
.case-back-wrap{
  width:min(1240px,calc(100% - 48px));
  margin:22px auto 0;
  font-family:Inter,system-ui,sans-serif;
}
.case-back-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#171713;
  font-size:11px;
  font-weight:500;
  letter-spacing:.14em;
  line-height:1;
  text-decoration:none;
  text-transform:uppercase;
}
.case-back-link::before{
  content:"←";
  font-size:14px;
  line-height:1;
}
@media(max-width:780px){
  .jb-announcement{
    min-height:42px;
    padding:9px 18px;
    gap:8px;
    flex-wrap:wrap;
    font-size:10px;
    letter-spacing:.09em;
  }
  .jb-nav{
    width:min(1240px,calc(100% - 32px));
    grid-template-columns:42px 1fr 42px;
  }
  .jb-links{display:none}
  .jb-menu-toggle{
    display:flex;
    grid-column:3;
    justify-self:end;
  }
  .jb-brand{
    grid-column:2;
    justify-self:center;
  }
  .jb-mobile-menu{
    display:block;
    max-height:0;
    overflow:hidden;
    border-top:1px solid rgba(23,23,19,.16);
    background:rgba(245,240,231,.86);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    transition:max-height .22s ease;
  }
  .jb-mobile-menu.is-open{max-height:420px}
  .jb-mobile-menu a{
    display:block;
    border-bottom:1px solid rgba(23,23,19,.16);
    padding:16px 24px;
    font-size:12px;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
  }
  .case-back-wrap{
    width:min(1240px,calc(100% - 32px));
    margin-top:16px;
  }
}

/* Shared image polish across pages. Keep logos/icons crisp and unmasked. */
body img:not([class*="logo"]):not([src$=".svg"]) {
  border-radius:20px !important;
}

.logo-marquee img,
.logo-track img,
.logo-group img,
.logo-placeholder img,
.site-logo img,
.nav-logo img,
.footer-logo img,
.site-footer-logo img,
img[class*="logo"],
img[src$=".svg"] {
  border-radius:0 !important;
}
