/* KICKBACK APP – SEXY BLACK + NEON GREEN VEGAS THEME (CLEAN PREMIUM HERO) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Montserrat:wght@700;800;900&family=Bebas+Neue&display=swap');

/* ==================== BASE / RESET ==================== */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; margin-top: 0 !important; padding-top: 0 !important; }

:root {
  --header-h: 86px;
  --sticky-h: 0px;
  --wpbar-h: 0px;

  /* ✅ HERO BG “ONE KNOB” (no more conflicting media blocks) */
  --hero-x: 65%;            /* desktop/tablet default */
  --hero-x-mobile: 92%;     /* mobile default */
}

body {
  font-family: 'Inter', sans-serif;
  background: #000;
  color: #fff;
  line-height: 1.6;
  overflow-x: hidden;
  padding-top: var(--header-h);
  padding-bottom: var(--sticky-h);
}

img, video, svg { max-width: 100%; height: auto; display: block; }
section { scroll-margin-top: calc(var(--header-h) + 16px); }

/* Kill default link styling anywhere it sneaks in */
a, a:visited { color: inherit; text-decoration: none; }

/* ==================== LAYOUT HELPERS ==================== */
.container,
.header-container,
.welcome-container {
  width: min(1400px, calc(100% - 40px));
  margin: 0 auto;
}

.cards-grid,
.testimonials-grid {
  width: min(1400px, calc(100% - 40px));
  margin: 0 auto;
  padding: 0;
}
/* In-Car Digital Screens card video */
.kb-ad-video{
  width: 100%;
  margin: 14px auto 10px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(57,255,20,0.18);
  background: #000;
  box-shadow: 0 18px 55px rgba(0,0,0,0.45);
}

.kb-ad-video-el{
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}


/* ==================== HEADER ==================== */
.sexy-header {
  position: fixed;
  top: 0 !important;
  left: 0;
  width: 100%;
  z-index: 1000;

  background: rgba(0,0,0,0.94);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);

  border-bottom: 1px solid rgba(57, 255, 20, 0.3);
  box-shadow: 0 4px 20px rgba(57, 255, 20, 0.2);
}

.header-container {
  padding: 12px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  min-height: var(--header-h);
}

.sexy-logo .kickback-link {
  text-decoration: none;
  font-family: 'Bebas Neue', sans-serif;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 5px;
  display: inline-flex;
  align-items: flex-end;
  line-height: 1;
  white-space: nowrap;
  gap: 0 !important;
}

.kb-client-logo{
  height: 60px;
  width: auto;
  display: block;
  object-fit: contain;
  margin: 0 !important;
  padding: 0 !important;
}

.app {
  color: #fff;
  font-size: clamp(22px, 3.2vw, 40px);
  font-weight: 900;
  letter-spacing: 3px;
  margin-bottom: 6px;
  margin-left: 0 !important;
  padding-left: 0 !important;
  transform: translateX(-10px);
  opacity: 0.95;
}

.desktop-nav {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}

.desktop-nav a {
  color: #fff;
  text-decoration: none;
  font-size: 18px;
  font-weight: 600;
  opacity: 0.9;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.desktop-nav a:hover {
  opacity: 1;
  color: #39FF14;
  text-shadow: 0 0 10px #39FF14;
}

.call-btn {
  background: #39FF14;
  color: #000 !important;
  padding: 10px 20px;
  border-radius: 30px;
  font-weight: 900;
  transition: all 0.35s ease;
}

.call-btn:hover {
  background: #fff;
  box-shadow: 0 0 20px #39FF14;
  transform: translateY(-2px);
}

/* Burger */
.kb-burger {
  display: none;
  flex-direction: column;
  background: none;
  border: none;
  cursor: pointer;
  padding: 10px;
}
.kb-burger span {
  width: 30px;
  height: 3px;
  background: #39FF14;
  margin: 4px 0;
  box-shadow: 0 0 10px #39FF14;
  border-radius: 2px;
}

/* Mobile nav */
#kb-mobile-nav {
  display: block;
  position: absolute;
  top: 100%; left: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  padding: 12px 0 18px;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.10);
}
#kb-mobile-nav[hidden] { display: none !important; }
#kb-mobile-nav a {
  display: block;
  color: #fff;
  padding: 16px 18px;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
}
#kb-mobile-nav a:hover {
  background: rgba(57, 255, 20, 0.15);
  color: #39FF14;
}

/* ==================== FEATURED IN ==================== */
.kb-pressbar {
  padding: 22px 0;
  margin-top: 0 !important;
  background:
    radial-gradient(900px 180px at 50% 0%, rgba(57,255,20,0.22), transparent 62%),
    rgba(0,0,0,0.92);
  border-top: 1px solid rgba(57,255,20,0.22);
  border-bottom: 1px solid rgba(57,255,20,0.22);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.kb-pressbar-inner {
  width: min(1280px, calc(100% - 40px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.kb-pressbar-left {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.kb-pressbar-label {
  font-weight: 900;
  letter-spacing: 0.8px;
  font-size: 1.08rem;
  color: #39FF14;
  text-shadow: 0 0 14px rgba(57,255,20,0.40);
}

.kb-pressbar-logos {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.kb-presslogo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(10,10,10,0.55);
  box-shadow: 0 14px 40px rgba(0,0,0,0.45);
}

.kb-presslogo-img{
  padding: 14px 22px !important;
  background: rgba(10,10,10,0.55);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 18px 55px rgba(0,0,0,0.55);
}

/* BASE SIZE (mobile-first) */
.kb-presslogo-img img{
  height: 34px;
  width: auto;
  display: block;
  filter: brightness(1.05) contrast(1.05);
}

@media (min-width: 640px){
  .kb-presslogo-img img{ height: 38px; }
}
@media (min-width: 900px){
  .kb-presslogo-img{ padding: 16px 26px !important; }
  .kb-presslogo-img img{ height: 42px; }
}
@media (min-width: 1200px){
  .kb-presslogo-img img{ height: 46px; }
}

.kb-pressbar-btn {
  appearance: none;
  border: 1px solid rgba(57,255,20,0.45);
  background: rgba(0,0,0,0.60);
  color: #39FF14;
  font-weight: 900;
  border-radius: 999px;
  padding: 12px 16px;
  cursor: pointer;
  font-size: 1.05rem;
  box-shadow: 0 16px 55px rgba(0,0,0,0.55);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.kb-pressbar-btn:hover {
  transform: translateY(-2px);
  background: rgba(57,255,20,0.10);
  box-shadow: 0 22px 70px rgba(57,255,20,0.12);
}

/* ==================== FEATURED IN — MAGAZINE COVERS ==================== */
.kb-pressbar-covers{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.kb-presscover{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 82px;
  height: 56px; /* small, premium strip size */
  border-radius: 14px;
  overflow: hidden;

  background: rgba(10,10,10,0.55);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 18px 55px rgba(0,0,0,0.55);
}

.kb-presscover img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: contrast(1.05) brightness(1.05);
  transform: scale(1.02);
}

/* little label chip */
.kb-presscover-tag{
  position: absolute;
  left: 8px;
  bottom: 7px;

  padding: 4px 8px;
  border-radius: 999px;

  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.02em;

  color: #fff;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(57,255,20,0.22);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Hover = subtle luxury lift */
.kb-presscover:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 70px rgba(57,255,20,0.10), 0 18px 55px rgba(0,0,0,0.55);
}

/* Mobile tuning: slightly larger + centered nicely */
@media (max-width: 640px){
  .kb-presscover{
    width: 96px;
    height: 64px;
    border-radius: 16px;
  }
  .kb-presscover-tag{
    font-size: 0.74rem;
    left: 9px;
    bottom: 8px;
  }
}


/* ==================== HERO (PREMIUM / NO GLASS) ==================== */
.hero.hero--image {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: calc(100svh - var(--header-h));
  min-height: calc(100svh - var(--header-h));
  display: flex;
  background: #000 !important;
}

.hero.hero--image .hero-bg{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--hero-x) center;
  z-index: 0;
}

.hero.hero--image .hero-shade{ display: none !important; }

.hero.hero--image::before{
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(900px 520px at 18% 22%, rgba(0,0,0,0.62), rgba(0,0,0,0.10) 55%, rgba(0,0,0,0) 75%),
    linear-gradient(180deg, rgba(0,0,0,0.22), rgba(0,0,0,0.02) 55%, rgba(0,0,0,0.12));
}

.hero.hero--image .hero-content{
  position: relative;
  z-index: 2;
  width: min(1200px, calc(100% - 40px));
  margin: 0 auto;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding: clamp(22px, 6vh, 92px) 16px 18px;
  gap: 16px;
}

.hero-text{
  width: 100%;
  max-width: 44ch;
  text-align: left;
}

.hero-text h1{
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: clamp(2.2rem, 4.6vw, 4.65rem);
  line-height: 1.03;
  letter-spacing: -1px;
  color: #fff;
  text-shadow:
    0 2px 18px rgba(0,0,0,0.55),
    0 18px 55px rgba(0,0,0,0.55);
}

/* Buttons */
.buttons{
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
  width: 100%;
  margin-top: auto;
}

.btn-primary,
.btn-outline {
  width: 100%;
  max-width: 420px;
  padding: 1.15rem 1.6rem;
  border-radius: 999px;
  font-weight: 900;
  font-size: 1.15rem;
  text-decoration: none;
  text-align: center;
  transition: all 0.35s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-primary {
  background: linear-gradient(135deg, #39FF14, #00d4ff);
  color: #000;
  box-shadow: 0 16px 40px rgba(57, 255, 20, 0.35);
}

.btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 25px 60px rgba(57, 255, 20, 0.55);
}

.btn-outline {
  background: transparent;
  color: #39FF14;
  border: 3px solid #39FF14;
}
.btn-outline:hover {
  background: #39FF14;
  color: #000;
}

.hero.hero--image .hero-buttons{ justify-content: center; }
.hero.hero--image .hero-buttons a[href^="tel:"]{ display: none !important; }

/* ==================== SECTIONS ==================== */
.welcome-section,
.advertise-section,
.contact-testimonials,
.why-section,
.kb-faq,
.kb-screenshots {
  padding: 80px 0;
  text-align: center;
}

.welcome-title,
.advertise-section h3,
.contact-header h3,
.why-section h3,
.kb-faq-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(2.0rem, 5vw, 4.8rem);
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 3rem;
  letter-spacing: -1px;
}

/* ==================== CARDS + GRIDS ==================== */
.cards-grid,
.testimonials-grid { display: grid; gap: 2rem; }
.cards-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.testimonials-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.cards-grid.advertise-cards { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }

.photo-card {
  background: #111;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
  position: relative;
}

.photo-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 25px 60px rgba(57, 255, 20, 0.2);
}

.card-inner {
  padding: 2.2rem;
  text-align: center;
  position: relative;
  z-index: 2;
}

.card-inner h4 {
  font-size: clamp(1.5rem, 4vw, 2.2rem);
  font-weight: 900;
  margin-bottom: 1rem;
}

.card-inner p {
  font-size: 1.1rem;
  opacity: 0.9;
  margin-bottom: 1.5rem;
}

.learn-more {
  color: #39FF14;
  font-weight: 800;
  text-decoration: none;
  font-size: 1.1rem;
  display: inline-block;
}
.learn-more:hover { text-shadow: 0 0 15px #39FF14; }

/* ==================== WELCOME ==================== */
.welcome-boxed {
  display: grid;
  grid-template-columns: 1fr;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 44px;
  overflow: hidden;
  box-shadow: 0 35px 110px rgba(0, 0, 0, 0.6);
}

.welcome-photo video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.welcome-textbox {
  background: #0a0a0a;
  padding: 3rem 1.5rem;
  text-align: left;
}

.welcome-textbox h3 {
  font-size: clamp(1.7rem, 4.5vw, 3.4rem);
  font-weight: 900;
  margin-bottom: 1.2rem;
  line-height: 1.15;
}

.welcome-textbox p {
  font-size: 1.1rem;
  margin-bottom: 1.25rem;
  opacity: 0.96;
}

.welcome-textbox .highlight {
  color: #39FF14;
  font-weight: 800;
  font-size: 1.15rem;
}

/* ==================== TRUST LOGO BAR (NEW) ==================== */
/* This targets the bar you added under the welcome-boxed */
.kb-trustbar{
  width: min(1200px, calc(100% - 40px));
  margin: 18px auto 0;
  padding: 16px 14px;

  border-radius: 22px;
  border: 1px solid rgba(57,255,20,0.16);
  background:
    radial-gradient(700px 120px at 50% 0%, rgba(57,255,20,0.12), rgba(0,0,0,0) 55%),
    rgba(10,10,10,0.55);

  box-shadow: 0 24px 90px rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.kb-trustbar-label{
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-size: 0.86rem;
  color: rgba(255,255,255,0.78);
  margin-bottom: 12px;
  text-align: center;
}

/* ✅ The key: consistent "logo tiles" with fixed height + contain */
.kb-trustbar-logos{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  align-items: center;
}

.kb-trustlogo{
  /* make each logo behave the same */
  width: 100%;
  height: 34px;               /* ✅ consistent height */
  object-fit: contain;        /* ✅ keeps proportions */
  object-position: center;
  display: block;

  /* put them in a sexy pill tile */
  padding: 10px 12px;         /* creates equal breathing room */
  border-radius: 16px;

  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 14px 45px rgba(0,0,0,0.45);

  filter: brightness(1.06) contrast(1.05);
  opacity: 0.95;

  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, opacity 0.22s ease;
}

.kb-trustlogo:hover{
  transform: translateY(-2px);
  opacity: 1;
  border-color: rgba(57,255,20,0.22);
  box-shadow: 0 22px 70px rgba(0,0,0,0.58);
}

/* Mobile: 2x2 grid + slightly smaller height */
@media (max-width: 640px){
  .kb-trustbar{ padding: 14px 12px; border-radius: 20px; }
  .kb-trustbar-logos{ grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
  .kb-trustlogo{ height: 30px; padding: 10px 10px; border-radius: 16px; }
}

/* Tablet/desktop: a little taller */
@media (min-width: 768px){
  .kb-trustlogo{ height: 38px; }
}

/* Big screens: slightly taller */
@media (min-width: 1100px){
  .kb-trustlogo{ height: 40px; }
}

/* ==================== RESULTS (WHY SECTION) ==================== */
.why-section > .container > h3{
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(2.0rem, 5vw, 4.8rem);
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 3rem;
  letter-spacing: -1px;
}

.why-section .cards-grid h3{
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(1.35rem, 1.6vw, 1.9rem) !important;
  line-height: 1.15 !important;
  margin: 0 0 12px !important;
  letter-spacing: -0.4px !important;
}

.why-section .cards-grid p{
  font-size: 1.05rem !important;
  line-height: 1.55 !important;
  opacity: 0.92;
  margin: 0 !important;
}

.why-section .cards-grid{ display: grid; gap: 24px; align-items: stretch; }

@media (min-width: 1100px){
  .why-section .cards-grid{ grid-template-columns: repeat(4, minmax(220px, 1fr)) !important; }
}
@media (min-width: 640px) and (max-width: 1099px){
  .why-section .cards-grid{ grid-template-columns: repeat(2, minmax(240px, 1fr)) !important; }
}
@media (max-width: 639px){
  .why-section .cards-grid{ grid-template-columns: 1fr !important; }
}
.why-section .photo-card{ padding: 28px !important; border-radius: 28px; }

/* ==================== SCREENSHOTS (UNIFORM SIZING) ==================== */
.kb-screenshots-shell { max-width: 1200px; margin: 0 auto; }

.kb-screenshots-track{ scrollbar-width: none; -ms-overflow-style: none; }
.kb-screenshots-track::-webkit-scrollbar{ height: 0; }

.kb-screenshots-track .kb-shot{
  flex: 0 0 auto;
  width: 260px;
  aspect-ratio: 9 / 19.5;
  border-radius: 18px;
  overflow: hidden;
  margin: 0 !important;
  position: relative;
  box-shadow: 0 18px 55px rgba(0,0,0,0.45);
  border: 1px solid rgba(57,255,20,0.18);
  background: #0b0b0b;
  scroll-snap-align: start;
}

.kb-screenshots-track .kb-shot img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
}

.kb-screenshots-track .kb-shot::after{
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 18px;
  box-shadow: inset 0 0 0 1px rgba(57,255,20,0.18);
  pointer-events: none;
}

@media (max-width: 900px){
  .kb-screenshots-track .kb-shot{ width: min(320px, 78vw); }
}
@media (max-width: 480px){
  .kb-screenshots-track .kb-shot{ width: min(300px, 84vw); }
}

/* ==================== CONTACT FORM ==================== */
.sexy-form-card {
  max-width: 900px;
  margin: 4rem auto 0;
  background: linear-gradient(135deg, #111 0%, #000 100%);
  padding: 3rem 1.5rem;
  border-radius: 44px;
  box-shadow: 0 20px 80px rgba(57, 255, 20, 0.15);
  border: 1px solid rgba(57, 255, 20, 0.2);
}

.sexy-contact-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.sexy-contact-form input,
.sexy-contact-form textarea {
  width: 100%;
  padding: 1.1rem 1.1rem;
  border-radius: 18px;
  border: 2px solid rgba(57, 255, 20, 0.3);
  background: rgba(17, 17, 17, 0.9);
  color: #fff;
  font-size: 1.05rem;
}

.sexy-contact-form input:focus,
.sexy-contact-form textarea:focus {
  outline: none;
  border-color: #39FF14;
  box-shadow: 0 0 25px rgba(57, 255, 20, 0.5);
  background: #000;
}

.sexy-contact-form textarea {
  min-height: 160px;
  resize: vertical;
}

.sexy-submit {
  width: 100%;
  max-width: 460px;
  margin: 0.75rem auto 0;
  padding: 1.15rem 1.6rem;
  font-size: 1.1rem;
}

/* ==================== MODAL ==================== */
.kb-modal { position: fixed; inset: 0; z-index: 20000; display: none; overflow: auto; -webkit-overflow-scrolling: touch; }
.kb-modal.is-open { display: block; }

.kb-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.kb-modal-dialog {
  position: relative;
  width: min(900px, calc(100% - 28px));
  margin: clamp(18px, 4vh, 40px) auto;
  background: linear-gradient(135deg, rgba(17,17,17,0.96), rgba(0,0,0,0.98));
  border: 1px solid rgba(57,255,20,0.20);
  border-radius: 26px;
  box-shadow: 0 30px 120px rgba(0,0,0,0.75);
  overflow: hidden;
  max-height: calc(100svh - 28px);
  display: flex;
  flex-direction: column;
}

.kb-modal-head {
  padding: 18px 18px 14px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex: 0 0 auto;
}

.kb-modal-body {
  padding: 18px;
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  min-height: 0;
}

.kb-modal-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(1.4rem, 3.2vw, 2.2rem);
  font-weight: 900;
  line-height: 1.1;
}

.kb-modal-x {
  appearance: none;
  border: 1px solid rgba(57,255,20,0.22);
  background: rgba(0,0,0,0.55);
  color: #39FF14;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  cursor: pointer;
  font-size: 18px;
  box-shadow: 0 14px 40px rgba(0,0,0,0.45);
  transition: transform 0.2s ease, background 0.2s ease;
}
.kb-modal-x:hover { transform: translateY(-2px); background: rgba(57,255,20,0.10); }

.kb-press-cards { display: grid; gap: 14px; grid-template-columns: 1fr; }

.kb-press-card {
  background: rgba(10,10,10,0.65);
  border: 1px solid rgba(57,255,20,0.14);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 18px 55px rgba(0,0,0,0.45);
}

.kb-press-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: 0.3px;
  color: #000;
  background: linear-gradient(135deg, #39FF14, #00d4ff);
}

.kb-press-link {
  margin-top: 12px;
  display: inline-block;
  color: #39FF14;
  font-weight: 900;
  text-decoration: none;
}
.kb-press-link:hover { text-shadow: 0 0 14px rgba(57,255,20,0.45); }

.kb-modal-actions {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

html.kb-modal-open,
body.kb-modal-open { overflow: hidden; }

/* ==================== STORE CTA (no purple, no underline) ==================== */
a.store-btn,
a.store-btn:visited{
  color: #fff !important;
  text-decoration: none !important;
}

/* If you have fallback text spans in HTML, hide them */
.store-btn .store-fallback{ display: none !important; }

/* Prevent any stray text inside the <a> from showing */
.store-btn{ font-size: 0; line-height: 0; }

/* Badge sizing */
.store-btn img{
  font-size: 16px; line-height: 1;
  height: 48px;
  width: auto;
  display: block;
}

.store-cta{
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

.store-kicker{
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.82;
}

.store-buttons{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.store-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(57,255,20,0.20);
  box-shadow: 0 18px 55px rgba(0,0,0,0.45);
  transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}

.store-btn:hover{
  transform: translateY(-2px);
  background: rgba(57,255,20,0.06);
  box-shadow: 0 24px 70px rgba(0,0,0,0.58);
}

.store-underline{
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 7px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(57,255,20,0), rgba(57,255,20,0.8), rgba(0,212,255,0.75), rgba(57,255,20,0));
  opacity: 0.55;
  transform: scaleX(0.35);
  transform-origin: center;
  transition: transform 0.35s ease, opacity 0.35s ease;
}
.store-btn:hover .store-underline{
  opacity: 0.95;
  transform: scaleX(1);
}

@media (max-width: 640px){
  .store-buttons{
    flex-direction: column;
    width: 100%;
    gap: 12px;
  }
  .store-btn{
    width: min(92%, 360px);
    justify-content: center;
  }
  .store-btn img{ height: 44px; }
}

/* ==================== RESPONSIVE ==================== */
@media (min-width: 768px) {
  :root { --header-h: 90px; --sticky-h: 0px; }

  .hero .buttons { flex-direction: row; justify-content: center; align-items: center; gap: 1.25rem; }
  .btn-primary, .btn-outline { width: auto; }

  .welcome-boxed { grid-template-columns: 1fr 1fr; align-items: stretch; grid-auto-rows: 1fr; }
  .welcome-textbox { padding: 4.5rem 3.5rem; display: flex; flex-direction: column; justify-content: center; }
  .form-grid { grid-template-columns: repeat(2, 1fr); }

  .kb-press-cards { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 900px) {
  :root { --header-h: 74px; }

  .desktop-nav { display: none; }
  .kb-burger { display: flex; }

  .kb-client-logo { height: 54px; }
  .app { transform: translateX(-14px); }
  .header-container { padding: 8px 0; }

  .kb-pressbar-inner { justify-content: center; text-align: center; }
  .kb-pressbar-left { justify-content: center; }
  .kb-pressbar-btn { width: 100%; max-width: 420px; }
}

@media (max-width: 640px) {
  :root {
    --header-h: 72px;
    --hero-x: var(--hero-x-mobile);
  }

  .hero.hero--image .hero-content{
    padding-top: 18px;
    padding-left: 14px;
    padding-right: 10px;
  }

  .hero-text{ max-width: 18ch; }
  .hero-text h1{
    font-size: clamp(1.55rem, 6.4vw, 2.05rem);
    line-height: 1.03;
    letter-spacing: -0.7px;
  }

  .kb-shot-arrow{ display: none !important; }

  h1, h2, h3, h4,
  .welcome-title,
  .why-section h3,
  .contact-header h3{
    overflow-wrap: normal !important;
    word-break: keep-all !important;
    hyphens: none !important;
  }
}

/* Client Logo scaling (desktop) */
@media (min-width: 1024px){ .kb-client-logo{ height: 82px; } }
@media (min-width: 1400px){ .kb-client-logo{ height: 90px; } }

/* ==================== WP ADMIN BAR (HIDDEN) ==================== */
body.admin-bar{ margin-top: 0 !important; }
#wpadminbar{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  transform: translateY(-120%) !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ==================== ADVERTISING OPTIONS: 4 IN A ROW (DESKTOP) ==================== */
@media (min-width: 1100px){
  .cards-grid.advertise-cards{
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 18px !important;
  }
  .cards-grid.advertise-cards .card-inner{ padding: 1.6rem !important; }
  .cards-grid.advertise-cards .card-inner h4{
    font-size: 1.5rem !important;
    line-height: 1.15 !important;
    margin-bottom: 0.75rem !important;
  }
  .cards-grid.advertise-cards .card-inner p{
    font-size: 1.0rem !important;
    margin-bottom: 1.0rem !important;
  }
  .cards-grid.advertise-cards .photo-card{ border-radius: 22px !important; }
}
/* =====================================================
   FINAL OVERRIDES — HERO POSITION + TRUST LOGOS (BIGGER)
   Paste at VERY BOTTOM so it wins
===================================================== */

/* 1) HERO: LOCK image position to 65% on ALL devices */
:root{
  --hero-x: 65% !important;
}
.hero.hero--image .hero-bg{
  object-position: 65% center !important; /* hard lock */
}

/* 2) TRUST LOGO BAR: BIGGER + READABLE + CONSISTENT */
.kb-trustbar{
  margin-top: 18px;
  padding: 16px 14px;
  border-radius: 22px;
  border: 1px solid rgba(57,255,20,0.18);
  background:
    radial-gradient(800px 140px at 50% 0%, rgba(57,255,20,0.14), rgba(0,0,0,0) 60%),
    rgba(10,10,10,0.62);
  box-shadow: 0 26px 95px rgba(0,0,0,0.60);
}

.kb-trustbar-label{
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-size: 0.90rem;
  color: rgba(255,255,255,0.82);
  margin-bottom: 12px;
  text-align: center;
}

/* Desktop/tablet: 4 across */
.kb-trustbar-logos{
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
  align-items: center !important;
}

/* The IMPORTANT part: give each logo a larger fixed HEIGHT, keep proportions */
.kb-trustlogo{
  width: 100% !important;
  height: 56px !important;           /* ✅ readable */
  object-fit: contain !important;    /* keeps consistency */
  object-position: center !important;

  padding: 12px 14px !important;     /* consistent breathing room */
  border-radius: 18px !important;

  background: rgba(0,0,0,0.42) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  box-shadow: 0 16px 55px rgba(0,0,0,0.55) !important;

  filter: brightness(1.08) contrast(1.08) !important;
  opacity: 0.98 !important;

  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease !important;
}

.kb-trustlogo:hover{
  transform: translateY(-2px) !important;
  border-color: rgba(57,255,20,0.25) !important;
  box-shadow: 0 24px 85px rgba(0,0,0,0.68) !important;
}

/* Mobile: 2x2 grid, still BIG */
@media (max-width: 640px){
  .kb-trustbar{
    padding: 14px 12px !important;
    border-radius: 20px !important;
  }

  .kb-trustbar-logos{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .kb-trustlogo{
    height: 62px !important;         /* ✅ even more readable on phones */
    padding: 12px 12px !important;
    border-radius: 18px !important;
  }
}

/* Extra big screens: slight bump */
@media (min-width: 1100px){
  .kb-trustlogo{
    height: 60px !important;
  }
}
/* =====================================================
   MOBILE GAP FIX — REMOVE EXCESS BLACK SPACE
   (between Why section + Get Listed)
===================================================== */
@media (max-width: 640px){

  /* Reduce bottom padding of the Why section */
  .why-section{
    padding-bottom: 20px !important;
  }

  /* Reduce top padding of the Get Listed section */
  .contact-testimonials{
    padding-top: 24px !important;
  }

  /* Kill any accidental margin stacking */
  .why-section > .container,
  .contact-testimonials > .container{
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
}
/* ==================== FEATURED IN — MOBILE FIX (CLEAN + READABLE) ==================== */

/* Make the left side stack nicely */
.kb-pressbar-left{
  display: flex;
  align-items: center;
  gap: 14px;
}

/* Covers wrapper */
.kb-pressbar-covers{
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Cover card */
a.kb-presscover{
  position: relative;
  display: block;
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none !important;

  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 18px 55px rgba(0,0,0,0.60), 0 0 0 1px rgba(57,255,20,0.10);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

a.kb-presscover img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: brightness(1.14) contrast(1.12) saturate(1.06);
  transform: scale(1.02);
}

/* Premium shine */
a.kb-presscover::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(0,0,0,0.25));
}

/* Tag chip */
.kb-presscover-tag{
  position: absolute;
  left: 10px;
  bottom: 10px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 900;
  color: #fff;
  background: rgba(0,0,0,0.55);
  border: 1px solid rgba(57,255,20,0.22);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

a.kb-presscover:hover{
  transform: translateY(-2px);
  box-shadow: 0 26px 75px rgba(0,0,0,0.68), 0 0 0 1px rgba(57,255,20,0.20);
}

/* ---------- DESKTOP/TABLET SIZE ---------- */
@media (min-width: 901px){
  a.kb-presscover{
    width: 230px;
    height: 145px;
  }
}

/* ---------- MOBILE: MAKE IT LOOK GOOD ---------- */
@media (max-width: 900px){

  /* Stack the whole pressbar cleanly */
  .kb-pressbar-inner{
    justify-content: center;
    gap: 14px;
  }

  .kb-pressbar-left{
    width: 100%;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    gap: 10px;
  }

  .kb-pressbar-label{
    width: 100%;
    text-align: center;
    font-size: 1.05rem;
    letter-spacing: 0.12em;
  }

  /* 2-up grid look without needing grid markup */
  .kb-pressbar-covers{
    width: 100%;
    justify-content: center;
    gap: 12px;
  }

  /* ✅ TWO COVERS SIDE-BY-SIDE, SAME SIZE */
  a.kb-presscover{
    width: min(46vw, 210px);
    aspect-ratio: 16 / 10;     /* keeps them clean + consistent */
    height: auto;              /* aspect-ratio controls height */
    border-radius: 18px;
  }

  /* Make the button centered and not too huge */
  .kb-pressbar-btn{
    width: min(92%, 420px);
    margin: 0 auto;
  }
}

/* Extra-small phones: still 2-up, just slightly tighter */
@media (max-width: 420px){
  a.kb-presscover{
    width: min(44vw, 185px);
    border-radius: 16px;
  }
  .kb-presscover-tag{
    font-size: 0.8rem;
    padding: 6px 10px;
  }
}
/* =====================================================
   FEATURED IN (COVERS) — HARD FIX (MOBILE + TOP VISIBLE)
   Paste at VERY BOTTOM so it wins
===================================================== */

/* Make the pressbar layout behave */
.kb-pressbar-inner{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
}

/* Left area: label + covers */
.kb-pressbar-left{
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

/* Covers wrapper (support either class name) */
.kb-pressbar-covers,
.kb-pressbar-logos{
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

/* The clickable cover cards */
a.kb-presscover{
  position: relative !important;
  display: block !important;
  width: 240px !important;
  height: 150px !important;
  border-radius: 22px !important;
  overflow: hidden !important;

  background: rgba(0,0,0,0.35) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;

  box-shadow:
    0 18px 55px rgba(0,0,0,0.65),
    0 0 0 1px rgba(57,255,20,0.12) !important;

  text-decoration: none !important;
  transform: translateZ(0);
}

/* ✅ SHOW TOP OF COVER (masthead/logo) */
a.kb-presscover img{
  width: 100% !important;
  height: 100% !important;
  display: block !important;

  object-fit: cover !important;
  object-position: top center !important;  /* <-- THIS is the masthead fix */

  filter: brightness(1.10) contrast(1.10) saturate(1.05) !important;
  transform: scale(1.02) !important;
}

/* Premium shine */
a.kb-presscover::before{
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(0,0,0,0.18) 60%, rgba(0,0,0,0.28)) !important;
}

/* Tag chip */
.kb-presscover-tag{
  position: absolute !important;
  left: 10px !important;
  bottom: 10px !important;

  padding: 7px 12px !important;
  border-radius: 999px !important;

  font-size: 0.86rem !important;
  font-weight: 900 !important;

  color: #fff !important;
  background: rgba(0,0,0,0.55) !important;
  border: 1px solid rgba(57,255,20,0.22) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

a.kb-presscover:hover{
  transform: translateY(-2px) !important;
  box-shadow:
    0 26px 75px rgba(0,0,0,0.72),
    0 0 0 1px rgba(57,255,20,0.20),
    0 0 26px rgba(57,255,20,0.10) !important;
}

/* ---------------- MOBILE: make it look intentional ---------------- */
@media (max-width: 900px){

  .kb-pressbar-inner{
    justify-content: center !important;
    text-align: center !important;
  }

  .kb-pressbar-left{
    width: 100% !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
  }

  .kb-pressbar-label{
    width: 100% !important;
    text-align: center !important;
  }

  /* ✅ Force TWO-UP row on phones */
  .kb-pressbar-covers,
  .kb-pressbar-logos{
    width: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    justify-items: center !important;
    max-width: 520px !important;
    margin: 0 auto !important;
  }

  /* Big taps, consistent size */
  a.kb-presscover{
    width: 100% !important;
    height: 140px !important;
    max-width: 260px !important;
    border-radius: 18px !important;
  }

  /* Keep button below centered */
  .kb-pressbar-btn{
    width: min(92%, 420px) !important;
    margin: 6px auto 0 !important;
  }
}

/* Extra small phones */
@media (max-width: 420px){
  a.kb-presscover{
    height: 128px !important;
  }
}

