.elementor-3443 .elementor-element.elementor-element-2f44689{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:40px;--padding-bottom:10px;--padding-left:60px;--padding-right:60px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-3443 .elementor-element.elementor-element-0de30c4{text-align:center;}.elementor-3443 .elementor-element.elementor-element-0de30c4 .elementor-heading-title{font-family:"Montserrat", Sans-serif;font-size:22px;font-weight:600;color:#000000;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-3443 .elementor-element.elementor-element-16a7e09{text-align:center;font-family:"Inter", Sans-serif;font-size:14px;font-weight:400;color:#000000;}.elementor-3443 .elementor-element.elementor-element-2d3792e{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 30px;--row-gap:0px;--column-gap:30px;--padding-top:30px;--padding-bottom:0px;--padding-left:60px;--padding-right:60px;}.elementor-3443 .elementor-element.elementor-element-c8b40b0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-3443 .elementor-element.elementor-element-2b389dc{--display:flex;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-3443 .elementor-element.elementor-element-c8b40b0{--width:50%;}.elementor-3443 .elementor-element.elementor-element-2b389dc{--content-width:50%;}}@media(max-width:767px){.elementor-3443 .elementor-element.elementor-element-0de30c4{text-align:center;}.elementor-3443 .elementor-element.elementor-element-0de30c4 .elementor-heading-title{font-size:18px;}}/* Start custom CSS for html, class: .elementor-element-1ffb124 *//* =========================================================
   CONTINUE BUTTON FIX (NO COLOR CHANGE ON HOVER/CLICK)
========================================================= */

.s4u-continue-btn,
.s4u-continue-btn:focus,
.s4u-continue-btn:active,
.s4u-continue-btn:hover{
  background: #000000 !important;   /* your pink color */
  color: #ffffff !important;
  border: none !important;
  outline: none !important;
}

/* remove weird active/pressed shift */
.s4u-continue-btn:active{
  transform: translateY(0) !important;
  box-shadow: none !important;
}

/* optional: keep subtle premium hover (no color change) */
.s4u-continue-btn:hover{
  opacity: 0.95;
}

/* remove Elementor button overrides if any */
button.s4u-continue-btn{
  background-image: none !important;
}
/* center slot titles (Upload front / back / design) */
#s4u-upload-panel .s4u-upload-slot-head{
  text-align: center;
  display: flex;
  justify-content: center;
}

#s4u-upload-panel .s4u-upload-slot-title{
  text-align: center;
}
#s4u-upload-panel .s4u-upload-header{
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* center the title */
#s4u-upload-panel .s4u-upload-title{
  text-align: center;
}

/* center the net/gross line */
#s4u-upload-panel .s4u-upload-meta,
#s4u-upload-panel .s4u-upload-subtitle{
  justify-content: center;
  text-align: center;
}

/* =========================================================
   FORCE CORRECT UPLOAD HEADER SPACING
========================================================= */

/* real title class from your HTML */
#s4u-upload-panel .s4u-upload-title{
  font-size: 20px !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
  margin: 0 0 6px !important;
  letter-spacing: -0.01em !important;
}

/* header wrapper */
#s4u-upload-panel .s4u-upload-header{
  margin-bottom: 22px !important;
}

/* net/gross line */
#s4u-upload-panel .s4u-upload-subtitle,
#s4u-upload-panel .s4u-upload-meta{
  font-size: 12px !important;
  line-height: 1.5 !important;
  color: #7b8491 !important;
  margin: 0 0 14px !important; /* space below net/gross */
}

/* upload slot heading */
#s4u-upload-panel .s4u-upload-slot-head{
  margin-bottom: 10px !important;
}

#s4u-upload-panel .s4u-upload-slot-title{
  font-size: 13px !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  margin: 0 !important;
}

/* if single mode, keep same vertical rhythm */
#s4u-upload-panel.s4u-mode-single .s4u-upload-slots{
  margin-top: 0 !important;
}

/* =========================================================
   CONTINUE BUTTON FIXED POSITION
========================================================= */

/* make right panel a positioning context */
#s4u-upload-panel{
  position: relative;
  padding-bottom: 84px !important; /* reserve space for button */
}

/* keep preview layout stable */
#s4u-preview-wrap{
  margin-top: 22px !important;
  padding-top: 18px !important;
  border-top: 1px solid #ececec !important;
}

/* lock button position */
.s4u-continue-wrap{
  position: absolute !important;
  right: 0 !important;
  bottom: 0 !important;
  margin: 0 !important;
  display: flex !important;
  justify-content: flex-end !important;
  width: auto !important;
  z-index: 5;
}

.s4u-continue-btn{
  min-width: 220px !important;
  height: 50px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}

/* =========================================================
   MOBILE
========================================================= */
@media (max-width: 900px){
  #s4u-upload-panel{
    padding-bottom: 0 !important;
  }

  .s4u-continue-wrap{
    position: static !important;
    width: 100% !important;
    margin-top: 18px !important;
  }

  .s4u-continue-btn{
    width: 100% !important;
    min-width: 0 !important;
  }
}
/* =========================================================
   UPLOAD + PREVIEW SECTION
========================================================= */

/* ---------- RIGHT PANEL WRAPPER ---------- */
#s4u-upload-panel{
  padding-top: 6px;
}

/* ---------- UPLOAD HEADER ---------- */
#s4u-upload-panel .s4u-upload-head{
  margin-bottom: 22px;
}

#s4u-upload-panel .s4u-upload-main-title{
  margin: 0 0 12px;
  font-size: 24px;
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #111827;
  text-align: left;
}

#s4u-upload-panel .s4u-upload-meta{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 12px;
  line-height: 1.5;
  color: #7b8491;
  margin: 0;
}

#s4u-upload-panel .s4u-upload-meta .dot{
  color: #c8ced6;
}

/* ---------- SLOTS LAYOUT ---------- */
#s4u-upload-panel .s4u-upload-slots{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

#s4u-upload-panel.s4u-mode-single .s4u-upload-slots{
  grid-template-columns: 1fr;
}

#s4u-upload-panel .s4u-upload-slot{
  min-width: 0;
}

#s4u-upload-panel .s4u-upload-slot.is-hidden{
  display: none !important;
}

#s4u-upload-panel.s4u-mode-single .s4u-upload-slot[data-slot="front"]{
  max-width: 560px;
  width: 100%;
  margin: 0 auto;
}

/* ---------- SLOT HEADER ---------- */
#s4u-upload-panel .s4u-upload-slot-head{
  margin-bottom: 10px;
}

#s4u-upload-panel .s4u-upload-slot-title{
  margin: 0;
  font-size: 14px;
  line-height: 1.3;
  font-weight: 700;
  color: #111827;
  letter-spacing: -0.01em;
}

/* ---------- DROPZONE ---------- */
#s4u-upload-panel .s4u-upload-dropzone{
  min-height: 120px;
  padding: 18px 16px 16px;
  border: 1px dashed #d7dbe2;
  border-radius: 18px;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

#s4u-upload-panel.s4u-mode-single .s4u-upload-dropzone{
  min-height: 126px;
}

/* ---------- UPLOAD BUTTON ---------- */
#s4u-upload-panel .s4u-upload-btn{
  width: 160px;
  height: 40px;
  padding: 0 14px;
  border: 1px solid #d6dbe2;
  border-radius: 999px;
  background: #fff;
  color: #374151;
  font-size: 13px;
  line-height: 1;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  transition: border-color .2s ease, background .2s ease, transform .2s ease;
}

#s4u-upload-panel .s4u-upload-btn:hover{
  border-color: #bfc6cf;
  background: #fcfcfc;
  transform: translateY(-1px);
}

#s4u-upload-panel .s4u-upload-btn-icon,
#s4u-upload-panel .s4u-upload-btn img{
  width: 14px;
  height: 14px;
  object-fit: contain;
  flex: 0 0 14px;
}

/* ---------- HINT ---------- */
#s4u-upload-panel .s4u-upload-hint{
  margin-top: 12px;
  font-size: 10px;
  line-height: 1.55;
  color: #98a1ac;
  text-align: center;
}

#s4u-upload-panel .s4u-upload-hint span{
  color: #7d8793;
  font-weight: 500;
}

/* ---------- FILE LIST ---------- */
#s4u-upload-panel .s4u-file-list{
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 0;
  margin-bottom: 10px;
}

#s4u-upload-panel .s4u-file-card{
  position: relative;
  min-height: 58px;
  padding: 10px 12px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

#s4u-upload-panel .s4u-file-left{
  min-width: 0;
  flex: 1 1 auto;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

#s4u-upload-panel .s4u-file-icon{
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}

#s4u-upload-panel .s4u-file-icon img{
  width: 18px;
  height: 18px;
  object-fit: contain;
}

#s4u-upload-panel .s4u-file-meta{
  min-width: 0;
  flex: 1 1 auto;
}

#s4u-upload-panel .s4u-file-name{
  font-size: 11px;
  line-height: 1.3;
  font-weight: 500;
  color: #111827;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#s4u-upload-panel .s4u-file-sub{
  margin-top: 2px;
  font-size: 9px;
  line-height: 1.35;
  color: #9aa2ad;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
}

#s4u-upload-panel .s4u-meta-dot{
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #c9ced6;
  display: inline-block;
}

#s4u-upload-panel .s4u-file-right{
  flex: 0 0 auto;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

#s4u-upload-panel .s4u-file-delete{
  width: 14px;
  height: 14px;
  padding: 0;
  border: 0;
  background: transparent;
  opacity: .75;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

#s4u-upload-panel .s4u-file-delete:hover{
  opacity: 1;
}

#s4u-upload-panel .s4u-file-delete img{
  width: 11px;
  height: 11px;
  object-fit: contain;
}

#s4u-upload-panel .s4u-file-status{
  font-size: 10px;
  line-height: 1.2;
  font-weight: 500;
  color: #4b5563;
  white-space: nowrap;
  margin-top: 1px;
}

#s4u-upload-panel .s4u-progress{
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 8px;
  height: 3px;
  background: #eceef2;
  border-radius: 999px;
  overflow: hidden;
}

#s4u-upload-panel .s4u-progress-bar{
  height: 100%;
  border-radius: 999px;
  background: #111827;
}

/* ---------- PREVIEW SECTION ---------- */
#s4u-preview-wrap{
  grid-column: 1 / -1;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid #ececec;
}

#s4u-preview-wrap .s4u-preview-head{
  margin-bottom: 14px;
}

#s4u-preview-wrap .s4u-preview-title{
  margin: 0;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 700;
  color: #111827;
  letter-spacing: -0.01em;
}

#s4u-preview-stage{
  position: relative;
  min-height: 420px;
  border: 1px solid #e6e8ed;
  border-radius: 20px;
  background: #f7f7f7;
  overflow: hidden;
}

#s4u-preview-stage canvas{
  display: block;
  width: 100% !important;
  height: 420px !important;
}

/* ---------- PREVIEW CONTROLS ---------- */
#s4u-preview-stage .s4u-preview-controls{
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#s4u-preview-stage .s4u-preview-controls button{
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  color: #1f2937;
  font-size: 17px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(17, 24, 39, 0.10);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

#s4u-preview-stage .s4u-preview-controls button:hover{
  transform: translateY(-1px);
  background: #fff;
  box-shadow: 0 10px 22px rgba(17, 24, 39, 0.14);
}

#s4u-fold-toggle{
  width: 54px !important;
  font-size: 12px !important;
}

/* ---------- CONTINUE BUTTON ---------- */
.s4u-continue-wrap{
  display: flex;
  justify-content: flex-end;
  margin-top: 22px;
}

.s4u-continue-btn{
  min-width: 220px;
  height: 50px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: #111827;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  box-shadow: 0 12px 24px rgba(17, 24, 39, 0.14);
}

.s4u-continue-btn:hover{
  transform: translateY(-1px);
}

.s4u-continue-btn:disabled{
  opacity: .65;
  cursor: not-allowed;
  transform: none;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px){
  #s4u-upload-panel .s4u-upload-main-title{
    font-size: 22px;
  }

  #s4u-upload-panel .s4u-upload-head{
    margin-bottom: 18px;
  }

  #s4u-upload-panel .s4u-upload-slots{
    grid-template-columns: 1fr;
    gap: 14px;
  }

  #s4u-upload-panel.s4u-mode-single .s4u-upload-slot[data-slot="front"]{
    max-width: 100%;
  }

  #s4u-upload-panel .s4u-upload-dropzone{
    min-height: 112px;
  }

  #s4u-preview-wrap{
    margin-top: 20px;
    padding-top: 18px;
  }

  #s4u-preview-stage{
    min-height: 360px;
  }

  #s4u-preview-stage canvas{
    height: 360px !important;
  }

  .s4u-continue-wrap{
    justify-content: stretch;
  }

  .s4u-continue-btn{
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 640px){
  #s4u-upload-panel .s4u-upload-main-title{
    font-size: 20px;
  }

  #s4u-upload-panel .s4u-upload-meta{
    font-size: 11px;
    gap: 8px;
  }

  #s4u-upload-panel .s4u-upload-slot-title{
    font-size: 13px;
  }

  #s4u-preview-wrap .s4u-preview-title{
    font-size: 17px;
  }

  #s4u-preview-stage .s4u-preview-controls{
    left: 10px;
    gap: 8px;
  }

  #s4u-preview-stage .s4u-preview-controls button{
    width: 38px;
    height: 38px;
    font-size: 15px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-03c0e9f */.s4u-continue-wrap{
  display:flex;
  justify-content:flex-end;
}

.s4u-continue-btn{
  min-width:220px;
  height:52px;
  padding:0 22px;
  border:none;
  border-radius:9999px;
  background:#000000;
  color:#fff;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  transition:all .2s ease;
  box-shadow:0 10px 24px rgba(17,24,39,.14);
}

.s4u-continue-btn:hover{
  transform:translateY(-1px);
  opacity:.96;
  background-color: #000000;
  color: #fff;
}

.s4u-continue-btn:disabled{
  opacity:.65;
  cursor:not-allowed;
  transform:none;
}/* End custom CSS */
/* Start custom CSS */@media (min-width: 2000px) and (max-width: 2800px) {.elementor-3443 .elementor-element.elementor-element-63f1bf0 .elementor-heading-title{
    font-size: 30px!important
}
.cart-wrapper{
     padding-left: 300px;
        padding-right: 300px;
        /*padding-top: 100px;*/
        max-width: none;
}
.cart-wrapper button{
    font-size:18px;
}
.cps-info-icon{
    font-size:12px!important;
}
}/* End custom CSS */