.nkBanner, .nkBanner *{ box-sizing: border-box; }

/* Elementor/theme “button” styles can bleed in. Reset inside banner. */
.nkBanner button,
.nkBanner a{
  font: inherit !important;
  color: inherit !important;
  text-decoration: none !important;
}
.nkBanner button{
  -webkit-appearance: none !important;
  appearance: none !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0;
  margin: 0;
  line-height: inherit;
  box-shadow: none !important;
}
.nkBanner img{ max-width: 100% !important; }

.nkBanner{
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Helvetica Neue", Helvetica, sans-serif;
  color: #0f172a;
}

/* Vertical “phone card” layout for narrow Elementor columns */
.nkBanner[data-layout="vertical"]{
  max-width: 420px;
}

.nkBannerCard{
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.12);
  background: #fff !important;
  box-shadow: 0 18px 50px rgba(2,6,23,.12) !important;
  overflow: hidden;
  cursor: pointer;
}

.nkBannerCard:focus-visible{
  outline: 3px solid rgba(99,102,241,.55);
  outline-offset: 4px;
}

.nkBannerTop{
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  padding: 14px 14px 10px;
  background: linear-gradient(90deg, rgba(0,0,0,.05), rgba(0,0,0,0));
}

.nkBrand{ min-width: 180px; }
.nkTitle{ font-weight: 1000; letter-spacing: -0.02em; font-size: 20px; }
.nkSub{ font-weight: 800; opacity: .75; font-size: 12px; margin-top: 2px; }

.nkSlogan{
  margin-top: 8px;
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12) !important;
  background: rgba(99,102,241,.10) !important;
  color: rgba(15,23,42,.92) !important;
  font-weight: 1000;
  font-size: 12px;
  letter-spacing: .2px;
  line-height: 1.1;
  max-width: min(92vw, 520px);
}
.nkBanner[data-layout="vertical"] .nkSlogan{
  max-width: min(92vw, 360px);
}
.nkSlogan.isPop{
  animation: nkSloganPop 520ms ease;
}
@keyframes nkSloganPop{
  0%   { transform: translateY(6px) scale(.98); opacity: 0; filter: blur(0.2px); }
  45%  { transform: translateY(-2px) scale(1.02); opacity: 1; }
  100% { transform: translateY(0) scale(1); opacity: 1; filter: none; }
}

.nkBanner[data-layout="vertical"] .nkBannerTop{
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.nkBanner[data-layout="vertical"] .nkBrand{ min-width: 0; }
.nkBanner[data-layout="vertical"] .nkTitle{ font-size: 22px; }

.nkFeeds{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}
.nkBanner[data-layout="vertical"] .nkFeeds{ justify-content: center; }

.nkFeed{
  border: 1px solid rgba(15,23,42,.14) !important;
  background: #fff !important;
  border-radius: 999px;
  padding: 7px 10px !important;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  font-weight: 900;
  opacity: .92;
  user-select: none;
  box-shadow: none !important;
}
.nkFeed.isActive{
  background: rgba(99,102,241,.10) !important;
  border-color: rgba(99,102,241,.35) !important;
}
.nkFeed:active{ transform: translateY(1px); }

.nkBannerBody{
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 14px;
  padding: 14px;
  align-items: center;
}
.nkBanner[data-layout="vertical"] .nkBannerBody{
  grid-template-columns: 1fr;
  gap: 12px;
}

.nkMedia{
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  border-radius: 14px;
  overflow: hidden;
  background: radial-gradient(800px 240px at 40% 0%, rgba(0,0,0,.10), transparent), #eef2ff;
}
.nkImg{ width: 100%; height: 100%; object-fit: cover; display: block; }
.nkImgShade{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.18));
  pointer-events: none;
}

.nkArrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.18) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.18) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 1100;
  cursor: pointer;
  user-select: none;
}
.nkArrow:active{ transform: translateY(-50%) scale(0.98); }
.nkPrev{ left: 10px; }
.nkNext{ right: 10px; }

.nkImgCap{
  font-size: 12px;
  font-weight: 850;
  color: rgba(15,23,42,.70);
  line-height: 1.25;
}
.nkImgCap.hidden{ display: none; }

.nkCopy{ min-width: 0; }
.nkBanner[data-layout="vertical"] .nkCopy{ text-align: center; }

.nkHeadline{
  font-size: 18px;
  font-weight: 950;
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.nkMeta{
  margin-top: 8px;
  font-size: 13px;
  opacity: .78;
  font-weight: 800;
}
.nkCta{
  margin-top: 12px;
  display: inline-block;
  border-radius: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(15,23,42,.14) !important;
  background: rgba(15,23,42,.06) !important;
  font-weight: 1000;
  box-shadow: none !important;
}
.nkBanner[data-layout="vertical"] .nkCta{
  width: 104px;
  height: 104px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  background: #111827 !important;
  border-color: rgba(17,24,39,.28) !important;
  color: #fff !important;
  box-shadow: 0 20px 54px rgba(0,0,0,.26) !important;
  font-size: 16px;
}

.nkPitch{
  margin-top: 10px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(15,23,42,.03);
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 850;
  color: rgba(15,23,42,.78);
  text-align: center;
}
.nkBanner[data-layout="vertical"] .nkPitch{
  max-width: 320px;
  margin-left: auto;
  margin-right: auto;
}

.nkTicker{
  border-top: 1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.03);
  overflow: hidden;
  padding: 10px 0;
}
.nkTickerTrack{
  display: inline-flex;
  gap: 34px;
  white-space: nowrap;
  align-items: center;
  will-change: transform;
  animation: nkTickerMarquee 22s linear infinite;
}
.nkTickerText{
  font-size: 13px;
  font-weight: 950;
  opacity: .88;
  padding-left: 14px;
  padding-right: 14px;
}
@keyframes nkTickerMarquee{
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.nkBanner.isLoading .nkHeadline{ opacity: .75; }
.nkBanner.isError .nkHeadline{ opacity: .95; }

@media (prefers-reduced-motion: reduce){
  .nkTickerTrack{ animation: none; }
}

@media (max-width: 720px){
  .nkBannerBody{ grid-template-columns: 1fr; }
  .nkFeeds{ justify-content: flex-start; }
}

