/* ================================
   WP Product Customizer – Frontend
   Uses CSS variables injected from settings:
   --wpcp-bg, --wpcp-text, --wpcp-accent, --wpcp-font,
   --wpcp-radius, --wpcp-shadow, --wpcp-width, --wpcp-height, --wpcp-progress
   ================================ */

/* Woo add-to-cart align tweak (theme-dependent) */
.woocommerce-js div.product form.cart .button{
  float: right !important;
}

div.wpcp-step:nth-child(1) > h4:nth-child(n){
		  font-family: var(--wpcp-font), system-ui, sans-serif !important;
}
/* Apply selected font everywhere in the offcanvas */
.wpcp-offcanvas,
.wpcp-offcanvas * {
  font-family: var(--wpcp-font), system-ui, sans-serif !important;
}



/* Off-canvas root (use opacity/visibility so transitions run) */
.wpcp-offcanvas{
  position:fixed;
  inset:0;
  z-index:100000; /* ensure above theme overlays */
  color: var(--wpcp-text);
  font-family: var(--wpcp-font);

  /* hidden state */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;

  transition: opacity .35s ease, visibility .35s ease;
}
.wpcp-offcanvas.is-open{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Backdrop (fade/blur on open) */
.wpcp-offcanvas__backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.4);
  backdrop-filter:blur(2px);
  z-index:100001;
  opacity: 0;
  transition: opacity .35s ease;
}
.wpcp-offcanvas.is-open .wpcp-offcanvas__backdrop{ opacity: 1; }

/* Panel (slides in from right on desktop) */
.wpcp-offcanvas__panel{
  position:absolute;
  right:0; top:0;
  height:100%;
  width: var(--wpcp-width, 25vw);
  max-width:480px; min-width:320px;
  background: var(--wpcp-bg, #fff);
  color: var(--wpcp-text, #111);
  box-shadow:-12px 0 30px rgba(0,0,0, calc(var(--wpcp-shadow,18) / 30));
  z-index:100002;
  border-radius: var(--wpcp-radius, 12px) 0 0 var(--wpcp-radius, 12px);

  /* animation */
  transform: translateX(110%);
  transition: transform .45s cubic-bezier(.22,1,.36,1);
  will-change: transform;
}
.wpcp-offcanvas.is-open .wpcp-offcanvas__panel{ transform: translateX(0); }

/* Close */
.wpcp-offcanvas__close{
  position:absolute; top:6px; right:8px;
  border:0; background:transparent;
  font-size:28px; line-height:1; cursor:pointer;
  color: inherit;
  font-size: 12px;
  padding: 6px;
}

/* Content layout */
.wpcp-offcanvas__content{
  height:100%;
  display:flex; flex-direction:column;
  padding:16px;
  overflow:hidden;
}

/* Steps area */
.wpcp-steps{ flex:1; overflow:auto; padding-right:8px; }
.wpcp-step{
  display:none;
  padding-bottom:16px;
  border-bottom:1px solid rgba(0,0,0,.06);
  margin-bottom:12px;
}
.wpcp-step.is-active{ display:block; }
.wpcp-step h4{
  margin:0 0 8px 0;
  font-size:16px; font-weight:600;
  color: var(--wpcp-text, #111);
  font-family: var(--wpcp-font) !important;
}

.wpcp-step h4{
	  font-family: var(--wpcp-font) !important;
}
/* Inputs */
.wpcp-field{ margin-bottom:12px; }
.wpcp-input input[type=text],
.wpcp-input input[type=number],
.wpcp-input select,
.wpcp-input textarea{
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius: var(--wpcp-radius, 12px);
  padding:10px 12px;
  font-size:14px;
  outline:none;
  background: #fff;
  background: color-mix(in srgb, var(--wpcp-bg, #fff) 96%, #fff);
  color: var(--wpcp-text, #111);
}
.wpcp-input input:focus,
.wpcp-input select:focus,
.wpcp-input textarea:focus{
  border-color: var(--wpcp-accent, #8e61ff);
}

/* Inline error */
.wpcp-err{ margin-top:6px; color:#c00; font-size:12px; }

/* Nav (sticky footer within panel) */
.wpcp-nav{
  position:sticky; bottom:0;
  display:flex; gap:8px; justify-content:flex-end;
  padding-top:12px; border-top:1px solid rgba(0,0,0,.06);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--wpcp-bg, #fff) 0%, transparent) 0%,
    var(--wpcp-bg, #fff) 40%);
}
.wpcp-nav .button{
  border-radius: var(--wpcp-radius, 12px);
  padding:8px 16px;
  line-height:1.2;
  transition:opacity .15s ease, transform .15s ease;
}
.wpcp-nav .button.alt,
.wpcp-next, .wpcp-submit{
  background: var(--wpcp-accent, #8e61ff);
  border-color: var(--wpcp-accent, #8e61ff);
  color:#fff;
  border-radius: var(--wpcp-radius, 12px);
}
.wpcp-nav .button:active{ transform:translateY(1px); }

/* Hide disabled buttons (JS also sets opacity/pointer-events) */
.wpcp-next[disabled], .wpcp-submit[disabled]{ display:none !important; }

/* Customize button on PDP */
.wpcp-customize-wrap{ margin:16px 0; }
.wpcp-customize-wrap .button{
  border-radius: var(--wpcp-radius, 12px);
  padding:.6rem 1.2rem;
  background: var(--wpcp-customize-bg, var(--wpcp-accent, #8e61ff));
  border-color: var(--wpcp-customize-bg, var(--wpcp-accent, #8e61ff));
  color: var(--wpcp-customize-text, #fff);
}

/* Specific selector for some themes’ nested structure */
div.summary.entry-summary > form > div.wpcp-customize-wrap > button{
  border-radius: var(--wpcp-radius, 12px);
  padding:.6rem 1.2rem;
  background: var(--wpcp-customize-bg, var(--wpcp-accent, #8e61ff));
  border-color: var(--wpcp-customize-bg, var(--wpcp-accent, #8e61ff));
  color: var(--wpcp-customize-text, #fff);
  border: 1px solid;
}

/* Progress bar (toggle via --wpcp-progress) */
.wpcp-progress{
  display: var(--wpcp-progress, none);
  height:6px;
  background:#f2f2f2;
  border-radius: var(--wpcp-radius, 12px);
  overflow:hidden;
  margin-bottom:12px;
}
.wpcp-progress__bar{
  height:100%;
  width:0%;
  background: var(--wpcp-accent, #8e61ff);
  transition:width .25s ease;
}

/* Mobile sheet style (slides up from bottom) */
@media (max-width: 782px){
  .wpcp-offcanvas__panel{
    left:0; right:auto; bottom:0; top:auto;
    width:100%; height: var(--wpcp-height, 80vh);
    transform: translateY(110%); /* hidden state */
    transition: transform .45s cubic-bezier(.22,1,.36,1);
    will-change: transform;
    border-radius: var(--wpcp-radius, 12px) var(--wpcp-radius, 12px) 0 0;
    box-shadow: 0 -12px 30px rgba(0,0,0, calc(var(--wpcp-shadow,18) / 30));
  }
  .wpcp-offcanvas.is-open .wpcp-offcanvas__panel{ transform: translateY(0); }
}

/* Modal */
.wpcp-modal{ position:fixed; inset:0; display:none; z-index:100010; }
.wpcp-modal.is-open{ display:block; }
.wpcp-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.5); }
.wpcp-modal__dialog{
  position:relative; margin:5vh auto 0 auto;
  max-width:560px; background: var(--wpcp-bg, #fff);
  color: var(--wpcp-text, #111);
  border-radius: var(--wpcp-radius, 12px);
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  padding:16px;
}
.wpcp-modal__close{
  position:absolute; top:6px; right:8px;
  border:0; background:transparent; font-size:24px; cursor:pointer; color: inherit;
}
.wpcp-modal__title{ margin:0 0 8px 0; }
.wpcp-modal__content ul{ list-style:none; margin:0; padding:0; }
.wpcp-modal__content li{ padding:6px 0; border-bottom:1px solid rgba(0,0,0,.08); }
.wpcp-modal__footer{ display:flex; justify-content:flex-end; gap:8px; padding-top:8px; }
.wpcp-modal__footer .button{
  background: var(--wpcp-accent, #8e61ff); color:#fff; border-radius:999px;
}


/* Loading spinner for submit/add-to-cart */
.wpcp-btn--loading{
  position: relative;
  color: transparent !important;       /* hide text */
  pointer-events: none;
}
.wpcp-btn--loading::after{
  content:"";
  position:absolute; top:50%; left:50%;
  width:1.1em; height:1.1em; margin:-0.55em 0 0 -0.55em;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.45);
  border-top-color: var(--wpcp-customize-text, #fff);
  animation:wpcp-spin .6s linear infinite;
}
@keyframes wpcp-spin{ to{ transform: rotate(360deg); } }

/* If your submit button isn’t “alt” (light background), use dark spinner contrast */
.wpcp-submit:not(.alt).wpcp-btn--loading::after{
  border-color: rgba(0,0,0,.25);
  border-top-color: var(--wpcp-text, #111);
}


/* Shake hint for invalid step */
@keyframes wpcp-shake {
  10%, 90% { transform: translateX(-1px); }
  20%, 80% { transform: translateX(2px); }
  30%, 50%, 70% { transform: translateX(-4px); }
  40%, 60% { transform: translateX(4px); }
}
.wpcp-shake{ animation: wpcp-shake .3s linear; }

/* Accessibility focus ring for close buttons */
.wpcp-offcanvas__close:focus,
.wpcp-modal__close:focus{
  outline: 2px solid var(--wpcp-accent, #8e61ff);
  outline-offset: 2px;
}

/* Dark theme tweaks for controls when bg is very dark */
@media (prefers-color-scheme: dark){
  .wpcp-input input[type=text],
  .wpcp-input input[type=number],
  .wpcp-input select,
  .wpcp-input textarea{
    background: color-mix(in srgb, var(--wpcp-bg, #0c0d0f) 96%, #111);
    border-color: color-mix(in srgb, var(--wpcp-bg, #0c0d0f) 40%, #444);
  }
}

/* Ensure WP/Woo buttons inside panel inherit theme */
.wpcp-offcanvas .button{
  border:1px solid transparent;
  font-weight:600;
}
/* Inline spinner element */
.wpcp-spinner{
  display:inline-block;
  width:1.1em; height:1.1em;
  margin-left:.5em;
  vertical-align:-0.2em;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.45);
  border-top-color: var(--wpcp-customize-text, #fff);
  animation:wpcp-spin .6s linear infinite;
}
.wpcp-submit:not(.alt) .wpcp-spinner{
  border-color: rgba(0,0,0,.25);
  border-top-color: var(--wpcp-text, #111);
}
@keyframes wpcp-spin{ to{ transform: rotate(360deg); } }

/* Dim the label while loading for visual feedback */
.wpcp-btn--loading { pointer-events:none; }
.wpcp-btn--loading > *:not(.wpcp-spinner){ opacity:.0; }

.wc-item-meta-label{
	line-height: 1.5px;
	margin-top: 1px;
	margin-bottom: 1px;
}

.wcf-instant-thankyou p, .wcf-instant-thankyou span, .wcf-instant-thankyou label, .wcf-instant-thankyou strong{
	line-height: 1.5px;
	margin-top: 1px;
	margin-bottom: 12px;
}