/* ===============================================================
   XinZuo – vlastní styly
   (verze s gravírovacími tlačítky, 2025‑07‑04)
   ===============================================================*/

/* ------------------------
   PŮVODNÍ PRAVIDLA
   ------------------------*/
.flag-kus,
.flag-sada {
  display: none !important;
}

.fvHide {
  display: none;
}

.fvCartPreviewImage {
  height: 60px;
  margin-top: 5px;
}

.fvEngravedLogoPreview {
  display: block;
  width: 100%;
  max-width: 340px;
  padding-top: 19px;
}

.fvEngravedLogo {
  margin-bottom: 19px;
}

#fvEngravedInput {
  max-width: 340px;
}

.fvEngravedLogoBtn {
  max-width: 340px;
  padding: 0 20px;
}

#fvEngravedLogoInput {
  display: none;
}

.fvEngravedDisabled {
  cursor: not-allowed !important;
}
.fvEngravedDisabled a,
.fvEngravedDisabled button,
.fvEngravedDisabled span,
.fvEngravedDisabled input,
.fvEngravedDisabled .remove-item {
  cursor: not-allowed !important;
  pointer-events: none;
}
.fvEngravedDisabled .remove-item {
  opacity: 0 !important;
}

.fvOrigTr {
  display: none !important;
  opacity: 0.2;
}

.fvRemoveitem {
  opacity: 0;
  vertical-align: middle;
  position: relative;
  margin: 0;
  padding: 10px;
  border: 0;
  text-align: right;
  line-height: 10px;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.fvRemoveitem::before {
  color: #000;
  content: "\e912";
  font-size: 10px;
  display: inline-block;
  speak: none;
  vertical-align: middle;
  font-family: shoptet;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  line-height: 0;
  text-transform: none;
  text-decoration: none;
  text-align: right;
}
.fvRemoveitem:hover::before {
  color: #d63500;
}

tr.removeable:hover .fvRemoveitem {
  opacity: 1;
}

.fvCartEtext {
  margin-top: 5px;
}
.fvCartEtext span {
  font-weight: 700;
}

.fvUploaderLoading {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.6666666667);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10101010;
}
.fvUploaderLoading:after {
  content: "";
  display: block;
  border: 16px solid #f3f3f3; /* Light grey */
  border-top: 16px solid #3498db; /* Blue */
  border-radius: 50%;
  width: 120px;
  height: 120px;
  -webkit-animation: spin 2s linear infinite;
          animation: spin 2s linear infinite;
  z-index: 10101011;
}

@-webkit-keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@media (min-width: 480px) {
  .fvEngraved .form-group label {
    line-height: 1.3;
    margin: 16px 0;
  }
}
@media (max-width: 768px) {
  .fvRemoveitem {
    opacity: 1 !important;
  }
}/*# sourceMappingURL=style.css.map */

/* ===============================================================
   GRAVÍROVÁNÍ – DROBNÉ ÚPRAVY
   ===============================================================*/

.fvEngraved .form-group:not(.fvHide.fvEngravedText):not(.fvHide.fvEngravedLogo) > label{
  font-weight:bold;
}

.fvEngravedLogoData-info{
  font-weight:bold;
  color:#e94b4b;
}

.fvEngraved .form-group:not(.fvHide.fvEngravedText):not(.fvHide.fvEngravedLogo){
  border-top:1px solid #e7e7e7;
  padding-top:10px;
}

/* šířka labelů – 480 px max, ale ať se zmenší na úzkých displejích */
.fvEngraved .form-group > label{
  width:480px;
  max-width:100%;
}

/* ===============================================================
   GRAVÍROVACÍ TLAČÍTKA – NOVÉ PRAVIDLA
   ===============================================================*/

/* 1) univerzální fix: formulář zarovnán doleva                  */
.fvEngraved .form-group{text-align:left!important}

/* 2) generický vzhled tlačítka                                   */
.fvEngravedButtons button{
  cursor:pointer;
  border:1px solid #d2d2d2;
  background:#f7f7f7;
  border-radius:8px;
  font:500 14px/1.2 "Inter",sans-serif;
  transition:background .2s,border .2s,box-shadow .2s;
}
.fvEngravedButtons button.active{
  background:#239b82;
  border-color:#239b82;
  color:#fff;
  box-shadow:0 0 0 2px rgba(35,155,130,.3);
}
.fvEngravedButtons button.active .price{
  color:#fff;                     /* cena zbělá také */
}
.fvEngravedButtons button:not(.active):hover{
  background:#fff;
  border-color:#ec100a;
}
.fvEngravedButtons span{
  font-size:12px;
  color:#666;
  margin-left:.25rem;
}

/* 3) MOBIL <768px – tlačítka pod sebou, 100 % šířky               */
@media(max-width:767.98px){
  .fvEngravedButtons{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:8px 0;
    width:100%!important;
    justify-content:flex-start;
  }
  .fvEngravedButtons button{
    flex:1 1 100%;
    padding:.75rem 1rem;
    white-space:normal;      /* může se zalomit */
  }
}

/* 4) DESKTOP ≥768px – tři tlačítka v jedné řadě                   */
@media(min-width:768px){
  .fvEngravedButtons{
    display:flex;
    flex-wrap:nowrap;
    gap:8px;
    margin:8px 0;
    width:100%!important;
    clear:both;             /* nový řádek pod labelem */
    justify-content:flex-start;
  }
  .fvEngravedButtons button{
    flex:1 1 0;             /* všechny stejně široké */
    min-height:48px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0 1.4rem;
    white-space:normal;     /* zalomí se, když je potřeba */
    text-align:center;
    flex-direction:column;
  }
}

/* ===== CENA V TLAČÍTKU  ===================================== */
/* mobil <768 px – cena inline (zůstává) */
.fvEngravedButtons .price{
  display:inline;
  margin-left:4px;
  font-size:14px;
  color:#000;
  white-space:nowrap;        /* drž (+ €12) pohromadě */
}

/* desktop ≥768 px – cena na vlastní řádek */
@media (min-width:768px){
  .fvEngravedButtons .price{
    display:block;           /* nový řádek pod textem  */
    margin:4px 0 0;          /* mezera shora           */
    white-space:nowrap;      /* nikdy nerozdělí (+ €)  */
  }
}