/* Skillful Johnson Box Inserter - Frontend styles */

.skjbi-box{
  position: relative;
  box-sizing: border-box;
  background: var(--skjbi-bg-color);
  border: var(--skjbi-border-width) solid var(--skjbi-border-color);
  border-radius: var(--skjbi-radius);
  padding: var(--skjbi-padding);
  overflow: hidden;

  font-family: var(--skjbi-font-family);
  font-size: var(--skjbi-font-size);
  font-weight: var(--skjbi-font-weight);
  color: var(--skjbi-font-color);
  text-align: var(--skjbi-align);
}

/* Background image layer */
.skjbi-box::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--skjbi-bg-image);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: var(--skjbi-bg-x) var(--skjbi-bg-y);
  opacity: var(--skjbi-bg-opacity);
  pointer-events: none;
  z-index: 0;
}

/* Keep content above background */
.skjbi-box > *{
  position: relative;
  z-index: 1;
}

.skjbi-title{
  font-size: var(--skjbi-title-size);
  font-weight: var(--skjbi-title-weight);
  color: var(--skjbi-title-color);
  margin: 0 0 10px 0;
}

.skjbi-body{
  margin: 0;
}

.skjbi-body p{
  margin: 0 0 10px 0;
}

.skjbi-body p:last-child{
  margin-bottom: 0;
}

.skjbi-actions{
  width: 100%;
  margin-top: var(--skjbi-btn-mt);
}

/* Button */
.skjbi-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: var(--skjbi-btn-bg) !important;
  color: var(--skjbi-btn-color) !important;
  -webkit-text-fill-color: var(--skjbi-btn-color) !important;
  border-radius: var(--skjbi-btn-radius) !important;
  padding: var(--skjbi-btn-py) var(--skjbi-btn-px) !important;
  font-size: var(--skjbi-btn-font-size) !important;
  font-weight: var(--skjbi-btn-font-weight) !important;
  min-height: var(--skjbi-btn-min-h, 44px);

  border-style: solid !important;
  border-width: var(--skjbi-btn-border-width) !important;
  border-color: var(--skjbi-btn-border-color) !important;

  text-decoration: none !important;
  cursor: pointer;
  box-shadow: none;
  transition: filter .15s ease, transform .15s ease, background-color .15s ease;
}

.skjbi-btn:hover{
  background: var(--skjbi-btn-hover-bg) !important;
  filter: brightness(0.98);
  transform: translateY(-1px);
}

.skjbi-btn:active{
  transform: translateY(0);
}

/* Optional: ensure it doesn't inherit theme link underlines */
.skjbi-box a.skjbi-btn{
  text-decoration: none !important;
}

.skjbi-btn *{
  color: var(--skjbi-btn-color) !important;
  -webkit-text-fill-color: var(--skjbi-btn-color) !important;
}


/* Theme-proof typography: ensure body text inherits from .skjbi-body inline styles */
.skjbi-body,
.skjbi-body *{
  color: inherit !important;
  font-family: inherit !important;
  font-size: inherit !important;
  font-weight: inherit !important;
}

/* Shortcode button positioning */
.skjbi-actions.skjbi-actions--h-left{ display:flex; justify-content:flex-start; }
.skjbi-actions.skjbi-actions--h-center{ display:flex; justify-content:center; }
.skjbi-actions.skjbi-actions--h-right{ display:flex; justify-content:flex-end; }

/* Vertical slots spacing */
.skjbi-actions--v-top{ margin: 0 0 10px 0; }
.skjbi-actions--v-middle{ margin: 10px 0 10px 0; }
.skjbi-actions--v-bottom{ margin: 12px 0 0 0; }
