
/****************************************************************************************************
    the form
****************************************************************************************************/

.form-container {
    position: relative;
    width: 100%;
    padding: 20px 6rem;
    font-size: small;
}

.form-container .form-title,
._panel-register ._column:nth-child(2) ._column-content ._column-title
{
    margin: 10px auto 30px auto;
    color: #ffffff;
    vertical-align: top;
    font-size: 24px;
    font-weight: 600;
    text-align: center;
}

._panel-register ._column:nth-child(2) ._column-content ._column-title
{
    margin-bottom: 10px;
}

.form-container .form-error {
    display: none;
	margin: 0 0 10px 0;
    padding: 6px 20px;
	background: #f2bfbf;
	border: 1px solid #cc0000;
    border-radius: 5px;
	color: #cc0000;
    text-align: left;
}

.form-container h3 {
    display: block;
    padding: 12px 20px;
    background: #00000050;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
}

.form-container .form-error p {
	color: #cc0000;
    text-align: left;
}

.form-container p,
.form-container p a
{
    color: #ffffff;
    font-weight: normal;
    font-size: 14px;
    font-weight: 600;
}

.form-container .form-input p
{
    display: block;
}

.form-container .form-input {
    margin: 0 0 20px;
    color: #ffffff;
    font-weight: normal;
    vertical-align: top;
}

.form-container .form-input a {
    color: inherit;
    font-weight: 600;
    vertical-align: top;
}

.form-container hr {
    clear: both;
    margin: 10px 20px;
    border: none;
    border-bottom: 1px solid #ffffff10;
}

.form-container .required,
.form-container .optional
{
    color: #FF3D00;
    font-size: 75%;
    vertical-align: top;
}

.form-container .optional
{
    color: #ffffff75;
}

.form-container .form-input .checkbox-label {
    display: inline;
    position: relative;
    left: 5px;
    vertical-align: top;
    font-size: 14px;
}

.form-input label {
    margin-bottom: 5px;
    color: #ffffff;
    font-size: small;
    font-weight: normal;
    letter-spacing: 0.05em;
}

.form-input label + .form-input-label-secondary
{
    margin-top: -5px;
    margin-bottom: 10px;
}


.form-container .form-input > .material-icons {
    font-size: 20px;
}

.form-input input[type="text"],
.form-input input[type="email"],
.form-input input[type="password"],
.form-input input[type="number"],
.form-input input[type="date"],
.form-input input[type="time"],
.form-input textarea,
.form-input select
{
    display: block;
    width: 100%;
    height: 40px;
    padding: 6px 10px 10px 10px;
    border: none;
    background: #00000030;
    box-shadow: 0 1px 0 #ffffff10;
    outline: none;
    outline-width: 0;
    border-radius: 5px;
    color: #ffffff;
    font-size: small;
}

.form-input textarea
{
    height: auto;
}

.form-input input[type="number"]
{
    display: inline-block;
}

.form-input input[type="number"],
.form-input input[type="date"],
.form-input input[type="time"]
{
    width: auto;
}

.form-input input[type="text"][disabled]
{
    color: rgba(255,255,255, .5);
    user-select: none;
}

.form-container .form-input .form-input-icon + input[type="text"],
.form-container .form-input .form-input-icon + input[type="email"],
.form-container .form-input .form-input-icon + input[type="password"],
.form-container .form-input .form-input-icon-focus + input[type="text"],
.form-container .form-input .form-input-icon-focus + input[type="email"],
.form-container .form-input .form-input-icon-focus + input[type="password"],
.form-container .form-input .form-input-icon + select
{
    padding-left: 45px;
}

/* macOS will ingore the padding */
.form-container .form-input .form-input-icon + select
{
    padding-left: 0;
    text-indent: 45px;
}

.form-container .form-input select:focus
{
    color: #000000;
    background: #ffffff;
}

.form-container form .form-input:first-child input[type="text"],
.form-container form .form-input:first-child input[type="email"],
.form-container form .form-input:first-child input[type="password"],
.form-container .form-input input[type="password"]:focus
{
    background: #00000090;
}

.form-container .form-input input[type="text"]::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #ffffff70;
    opacity: 1;
}

.form-container .form-input input[type="text"]:not(:placeholder-shown),
.form-container .form-input input[type="text"]:focus,
.form-container .form-input input[type="email"]:focus,
.form-container .form-input input[type="number"],
.form-container .form-input select
{
    background: #00000095;
}

.form-container .form-input .form-input-icon {
    position: absolute;
    display: block;
    width: 40px;
    height: 40px;
    padding-top: 8px;
    color: #ffffff90;
    text-align: center;
    vertical-align: middle;
    text-shadow: 0 1px 0 #000000;
}



.form-container .form-input button[name="delete"],
.form-container .form-input button[name="save"],
.form-container .form-input button[type="submit"],
.form-container .redirect-link
{
    display: inline-block;
    width: auto;
    height: 40px;
    margin: 15px 0;
    padding: 0 19px;
    background: linear-gradient(to bottom,
        #449d44,
        #008000
    );
    border: none;
    box-shadow: 0 1px 0 #00000030;
    border-radius: 5px;
    outline: none;
    color: #cccccc;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    text-shadow: 0 1px #00000080;
    text-transform: uppercase;
    cursor: pointer;
    line-height: 14px;
    vertical-align: middle;
}

.form-container .form-input button[disabled]{
    cursor: not-allowed;
    opacity: 0.6;
}

.form-container .form-input button + svg {
    font-size: 20px;
    margin-left: 10px;
}

.form-container .form-input button[name="delete"]
{
    background: linear-gradient(to bottom,
        #cc0000,
        #aa0000
    );
}

.form-container .redirect-link
{
    line-height: 40px;
    background: linear-gradient(to bottom,
        #337ab7,
        #204d74
    );
}

.form-container .form-input button[type="submit"].disabled,
.form-container .form-input button[type="submit"][disabled="disabled"]
{
    background: linear-gradient(to bottom,
        #222222,
        #333333
    );
    box-shadow: none;
    color: #cccccc25;
    text-shadow: none;
    cursor: not-allowed;
}

.form-input button[type="submit"] + button[type="submit"]
{
    margin-left: 10px;
}


.checkbox-replacement {
    display: inline-block;
    width: 22px;
    height: 22px;
    padding: 2px 0 0 0;
    background: #00000060;
    box-shadow:
        0 1px 0 #ffffff10,
        inset 0 2px 2px #000000;
    border-radius: 5px;
    color: #ffffff;
    text-align: center;
    overflow: hidden;
    cursor: pointer;
}

.checkbox-replacement .material-icons {
    color: #ffffff;
    font-size: 18px;
}

.form-container .form-input input[type="checkbox"],
.checkbox-replacement:not([checked="checked"]) .material-icons
{
    display: none;
}


.form-container .form-input .description {
	padding: 6px 0 6px 45px;
	background: #f2bfbf;
	border: 1px solid #cc0000;
    border-radius: 0 0 5px 5px;
	color: #cc0000;
    font-size: small;
    text-align: left;
}

.form-container .form-input .description:empty {
    display: none;
}




/****************************************************************************************************
    file buttons
****************************************************************************************************/

.form-container .form-input
{
    font-size: 0;
}

.form-container .form-input input[type="text"][valid],
.form-container .form-input input[type="text"][invalid],
.form-container .form-input input[type="email"][valid],
.form-container .form-input input[type="email"][invalid],
.form-container .form-input input[type="password"][valid],
.form-container .form-input input[type="password"][invalid]
{
    display: inline-block;
    width: calc(100% - 40px);
}

.form-container .form-input input[type="text"][valid] + .form-state-icon,
.form-container .form-input input[type="text"][invalid] + .form-state-icon,
.form-container .form-input input[type="email"][valid] + .form-state-icon,
.form-container .form-input input[type="email"][invalid] + .form-state-icon,
.form-container .form-input input[type="password"][valid] + .form-state-icon,
.form-container .form-input input[type="password"][invalid] + .form-state-icon
{
    position: relative;
    display: inline-block;
    width: 40px;
    height: 40px;
    padding-top: 8px;
    vertical-align: top;
    color: #449d44;
    text-align: center;
}

.form-container .form-input input[type="text"] + .form-state-icon,
.form-container .form-input input[type="email"] + .form-state-icon,
.form-container .form-input input[type="password"] + .form-state-icon
{
    display: none;
}

.form-container .form-input input[type="text"][invalid] + .form-state-icon .material-icons[icon="success"],
.form-container .form-input input[type="email"][invalid] + .form-state-icon .material-icons[icon="success"],
.form-container .form-input input[type="password"][invalid] + .form-state-icon .material-icons[icon="success"],
.form-container .form-input input[type="text"][valid] + .form-state-icon .material-icons[icon="error"],
.form-container .form-input input[type="email"][valid] + .form-state-icon .material-icons[icon="error"],
.form-container .form-input input[type="password"][valid] + .form-state-icon .material-icons[icon="error"]
{
    display: none;
}

/****************************************************************************************************
    form input focus
****************************************************************************************************/

.form-container .form-input-info
{
    margin: 6px 0;
    padding: 6px;
    background: #ffffff10;
    border: 1px dashed #ffffff10;
    border-radius: 3px;
    text-shadow: none;
    color: #ffffff;

    border: 2px solid #2196f3;
    border: 0;
    background: none;
    background: #00000050;
    background: #0061ae;
    background: #2196f380;

    color: rgba(0,0,0, .9);
    color: #2196f3;
    color: #ffffff;

    /*
    box-shadow:
        inset 0 1px 8px #00000080,
        inset 0 -1px 8px #00000080;
    */
}

.form-container .form-input-info .material-icons
{
    width: auto;
    height: auto;
    color: #2196f3;
    font-size: 24px;
}

.form-container .form-input-info span
{
    display: inline-block;
    width: calc(100% - 30px);
    margin-left: 6px;
    vertical-align: top;
    font-size: small;
}


/****************************************************************************************************
    invalid
****************************************************************************************************/

.form-container .form-input[invalid] input[type="text"],
.form-container .form-input[invalid] input[type="email"],
.form-container .form-input[invalid] input[type="password"],
.form-container .form-input[invalid] input[type="number"],
.form-container .form-input[invalid] select
{
    box-shadow: 0 1px 0 #cc0000;
}

.form-container .form-input[invalid] .form-input-icon {
    color: #cc000090;
}

.form-container .form-input[invalid] .form-input-info
{
    background: #f2bfbf;
    color: #cc0000;
}

.form-container .form-input[invalid] .form-input-info .material-icons
{
    color: #cc0000;
}


/****************************************************************************************************
    file buttons
****************************************************************************************************/

.form-container button[type="file"]
{
    display: block;
    width: auto;
    height: 40px;
    margin: 15px 0;
    padding: 0 19px;
    background: linear-gradient(to bottom,
        #337ab7,
        #204d74
    );
    border: none;
    box-shadow: 0 1px 0 #00000030;
    border-radius: 5px;
    outline: none;
    color: #cccccc;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    text-shadow: 0 1px #00000080;
    text-transform: uppercase;
    cursor: pointer;
    line-height: 40px;
    vertical-align: middle;
}

.form-container button.change-link,
.form-container a.change-link,
a.help-link
{
    display: inline;
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    box-shadow: none;
    outline: none;
    color: #3897f0;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    text-align: left;
    text-shadow: none;
    text-transform: none;
    cursor: pointer;
    line-height: normal;
    vertical-align: middle;
}

.form-step .form-step-title + button[type="file"]
{
    margin-top: 0;
}

.form-container button[type="file"] + input[type="file"] {
    position: absolute;
    top: -1000px;
}

.form-container input[type="file"] + input[type="text"]
{
    display: block;
    width: 100%;
    height: 40px;
    margin-top: 10px;
    padding: 6px 10px 10px 10px;
    border: none;
    box-shadow: 0 1px 0 #ffffff10;
    outline: none;
    outline-width: 0;
    border-radius: 5px;
    color: #666666;
    background: #00000030;
    font-size: 12px;
}

/****************************************************************************************************
    checkbox toggles
****************************************************************************************************/

.form-step input[type="checkbox"]
{
    display: none;
}

input[type="checkbox"] + button[type="toggle"]
{
    display: block;
    margin: 10px 0 0 0;
    padding: 0;
    vertical-align: top;
    background: none;
    border: 0;
    outline: 0;
    font-size: 0;
}

input[type="checkbox"] + button[type="toggle"] .toggle-switch,
input[type="checkbox"] + button[type="toggle"] .toggle-label
{
    display: inline-block;
    width: 60px;
    height: 30px;
    padding: 5px 5px;
    vertical-align: top;
    background: #000000;

    border-radius: 15px;
    text-align: left;

    box-shadow: 0 1px 0 #ffffff10;

}

input[type="checkbox"] + button[type="toggle"] .toggle-switch .toggle-slider
{
    width: 20px;
    height: 20px;
    background: #ffffff;
    border: 0;
    outline: 0;
    border-radius: 50%;
    display: inline-block;
    transition: margin .4s ease;

}

input[type="checkbox"] + button[type="toggle"] .toggle-label
{
    width: auto;
    height: 30px;
    margin-left: 5px;
    padding: 8px 0;
    background: none;
    line-height: 14px;
    box-shadow: none;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .1em;
    vertical-align: top;
}

input[type="checkbox"]:not(:checked) + button[type="toggle"] .toggle-switch .toggle-slider
{
    background: #bf273a;
    margin-left: 0;
}
input[type="checkbox"]:not(:checked) + button[type="toggle"] .toggle-label
{
    color: #bf273a;
}

input[type="checkbox"]:checked + button[type="toggle"] .toggle-switch .toggle-slider
{
    background: #64b95e;
    margin-left: calc(100% - 20px);
}
input[type="checkbox"]:checked + button[type="toggle"] .toggle-label
{
    color: #64b95e;
}

input[type="checkbox"]:not(:checked) + button[type="toggle"] .toggle-label[type="on"],
input[type="checkbox"]:checked + button[type="toggle"] .toggle-label[type="off"]
{
    display: none;
}

input[type="checkbox"]:not(:checked) + button[type="toggle"] + .form-linked
{
    display: none;
}

/****************************************************************************************************
    radio group
****************************************************************************************************/

.form-radio-item
{
    font-size: 0;
}

.form-radio-item input[type="radio"]
{
    display: none;
}

.form-radio-item button[type="radio-toggle"]
{
    display: inline-block;
    width: 24px;
    height: 24px;
    padding: 5px 5px;
    vertical-align: top;
    background: #000000;
    border: 0;
    outline: 0;
    border-radius: 15px;
    text-align: left;
    box-shadow: 0 1px 0 #ffffff10;
}

.form-radio-item button[type="radio-toggle"]:after {
    display: block;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid #ffffff20;
    content: "";
}

.form-radio-item:hover input ~ button[type="radio-toggle"]:after
{
    background-color: #ccc;
}

.form-radio-item input:checked ~ button[type="radio-toggle"]:after,
.form-radio-item:hover input:checked ~ button[type="radio-toggle"]:after
{
    background-color: #64b95e;
    border-color: #64b95e;
}

.form-radio-item input:disabled:checked ~ button[type="radio-toggle"]:after,
.form-radio-item:hover input:disabled:checked ~ button[type="radio-toggle"]:after
{
    background-color: #999999;
    border-color: #999999;
}

.form-radio-item label
{
    width: calc(100% - (24px + 8px));
    margin-left: 8px;
    background: none;
    box-shadow: none;
    font-size: 14px;
    font-weight: 600;
    vertical-align: top;
    padding: 5px 0;
    line-height: 14px;
    height: 24px;
    overflow: hidden;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #999999;
}

.form-radio-item input:checked ~ label {
    color: #ffffff;
}

.form-radio-group + .form-input{
    margin-top: 10px;
}


.form-radio-item img[vibratoy-data="QR"]
{
    max-width: 140px;
    margin-left: 34px;
}

/****************************************************************************************************
    radio toggles
****************************************************************************************************/

.form-step input[type="radio"]
{
    display: none;
}

input[type="radio"] + button[type="toggle"]
{
    display: block;
    width: 100%;
    height: auto;
    margin: 0 0 6px 0;
    padding: 0;
    vertical-align: top;
    background: none;
    border: 0;
    outline: 0;
    font-size: 0;
}

input[type="radio"] + button[type="toggle"] .toggle-switch,
input[type="radio"] + button[type="toggle"] .toggle-label
{
    display: inline-block;
    width: 24px;
    height: 24px;
    padding: 5px;
    vertical-align: top;
    background: #000000;
    border-radius: 12px;

    text-align: left;

    box-shadow: 0 1px 0 #ffffff10;

}

input[type="radio"] + button[type="toggle"] .toggle-switch .toggle-slider
{
    width: 14px;
    height: 14px;
    background: #ffffff;
    border: 0;
    outline: 0;
    border-radius: 50%;
    display: inline-block;
    transition: margin .4s ease;

}

input[type="radio"] + button[type="toggle"] .toggle-label
{
    width: calc(100% - (24px + 8px));
    margin-left: 8px;
    background: none;
    box-shadow: none;
    font-size: 14px;
    font-weight: 600;

    vertical-align: top;
    padding: 5px 0;
    line-height: 14px;
    height: 24px;

    overflow: hidden;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;

    color: #999999;
}

input[type="radio"] + button[type="toggle"] .toggle-switch .toggle-slider
{
    background: none;
    border: 2px solid #ffffff20;
}

input[type="radio"]:checked + button[type="toggle"] .toggle-switch .toggle-slider
{
    background: #64b95e;
}

input[type="radio"]:checked + button[type="toggle"] .toggle-label
{
    color: #ffffff;
}

input[type="radio"]:disabled + button[type="toggle"] .toggle-switch
{
    background: none;
    box-shadow: 0 0 0;
}

input[type="radio"]:disabled + button[type="toggle"] .toggle-label
{
    color: #666666;
}

input[type="radio"]:disabled + button[type="toggle"] .toggle-switch .toggle-slider
{
    background: none;
    border: 2px solid #ffffff10;
}

radiogroup div:last-child input[type="radio"] + button[type="toggle"]
{
    margin-bottom: 0;
}

.radiogroup-toggle
{
    cursor: pointer;
}

.radiogroup-toggle:not([closed="1"]) .material-icons[icon="open"],
.radiogroup-toggle[closed="1"] .material-icons[icon="closed"]
{
    display: none;
}

/****************************************************************************************************
    form steps
****************************************************************************************************/

.form-container button[type="minus"],
.form-container button[type="minus"] + input[type="number"],
.form-container button[type="plus"]
{
    display: inline-block;
    width: 50px;
    height: 30px;
    vertical-align: top;
    margin: 0;
    padding: 0 4px;
    border: 0;
    outline: 0;
    box-sizing: border-box;
    box-shadow: 0 1px 0 #ffffff10;
    font-size: 18px;
    font-weight: 600;
    text-align: center;
}

.form-container button[type="minus"] + input[type="number"],
.form-container button[type="minus"]:hover,
.form-container button[type="plus"]:hover
{
    background: #000000;
    color: #ffffff;
}

.form-container button[type="minus"],
.form-container button[type="plus"]
{
    width: 30px;
    background: #00000080;
    border-radius: 15px 0 0 15px;
    color: #ffffff50;
    font-size: 16px;
    text-align: center;
}

.form-container button[type="plus"]
{

    border-radius: 0 15px 15px 0;

}

.form-container button[type="minus"] .material-icons,
.form-container button[type="plus"] .material-icons
{
    display: block;
    width: 30px;
    margin-left: -4px;
    text-align: center;
    font-size: 16px;
    line-height: 30px;
    pointer-events: none;
}

.form-container input[type="number"] {
    -moz-appearance: textfield;
}

.form-container button[type="minus"] + input[type="number"]::-webkit-outer-spin-button,
.form-container button[type="minus"] + input[type="number"]::-webkit-inner-spin-button
{
    -webkit-appearance: none;
    margin: 0;
}

/****************************************************************************************************
    form steps
****************************************************************************************************/

.form-step
{
    width: 100%;
    margin: 10px auto;
    padding: 20px;
    border: 1px solid #ffffff10;
    border-radius: 3px;
}

.form-step .form-linked
{
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #ffffff10;
}

.form-step .form-step-icon
{
    margin-right: 6px;
}

.form-step .form-step-title
{
    display: inline-block;
    vertical-align: top;
    margin-bottom: 20px;
    color: #ffffff;
    font-size: 18px;
    font-weight: 600;
    text-align: left;
}

.form-step .form-linked .form-step-title
{
    font-size: 16px;
}

.form-step .form-step-title-secondary,
.form-input .form-input-label-secondary,
.form-step .form-step-readmore
{
    display: block;
    color: #ffffff50;
    /* rendering of alpha channel isn't consistent on all browsers */
    color: #999999;
    font-size: small;
    vertical-align: top;
}

.form-step .form-step-readmore
{
    display: none;
    width: 100%;
    margin: 10px auto;
    padding: 6px 10px 10px 10px;
    background: #ffffff10;
    border: 1px dashed #ffffff10;
    border-radius: 3px;
}

.form-step .form-step-title + .form-step-indent .form-step-title-secondary,
.form-step .form-step-title + .form-step-title-secondary
{
    overflow: hidden;
    height: 32px;
    margin-top: -20px;
    margin-bottom: 10px;
    line-height: 16px;
}

.form-container .form-step p,
.form-container .form-step p a
{
    display: block;
    color: #ffffff50;
    font-size: small;
    font-weight: normal;
    vertical-align: top;
}

.form-container .form-step p a
{
    font-weight: 600;
}

.form-step-img-container
{
    font-size: 0;
    vertical-align: top;
}

.form-step-img-container .form-step-img {
    display: inline-block;
    width: 50px;
    height: 50px;
    vertical-align: top;
    border-radius: 50%;
}

.form-step-img-container .form-step-img-container-content
{
    display: inline-block;
    width: calc(100% - (50px + 10px));
    margin-left: 10px;
    vertical-align: top;
}

.form-step .form-step-indent
{
    margin-left: 34px;
}

/****************************************************************************************************
    ajax update
****************************************************************************************************/

.form-ajax-update
{
    display: inline-block;
    width: auto;
    color: #ffffff50;
    font-size: small;
    font-weight: 600;
}

.form-ajax-update .form-ajax-update-onclick:hover
{
    text-decoration: underline;
    cursor: pointer;
}

.form-ajax-update .form-ajax-update-progress
{
    display: block;
    width: 100%;
    margin: 4px 0;
    height: 8px;
    background: #ffffff50;

    animation: ajaxProgress 2s forwards;
}

.form-ajax-update:not([status]) .form-ajax-update-progress,
.form-ajax-update:not([status="sent"]) .form-ajax-update-success
{
    display: none;
}

.form-ajax-update[status] .form-ajax-update-onclick,
.form-ajax-update .form-ajax-update-success
{
    opacity: 0;
    height: 0;
    overflow: hidden;
}

/*
keep the height so it doesn't dance around the stage
*/
.form-ajax-update[status="sending"]
{
    height: var(--height);
    overflow: hidden;
}

.form-ajax-update[status="sent"] .form-ajax-update-progress
{
    animation:
        fadeOut .5s 0s forwards,
        hideElement 0s .5s linear 1 forwards;
}

.form-ajax-update[status="sent"] .form-ajax-update-success
{
    animation:
        showElement 0s .5s linear 1 forwards,
        fadeIn .5s .5s forwards;
}

@keyframes ajaxProgress {
    0% {
        width: 0%;
    }
    100% {
        width: 100%;
    }
}

@keyframes hideElement {
	100% {
		height: 0;
		margin: 0;
		padding: 0;
        overflow: hidden;
	}
}

@keyframes showElement {
	100% {
		height: auto;
        overflow: auto;
	}
}

@keyframes fadeIn {
	0% {
        opacity: 0;
	}
	100% {
        opacity: 1;
	}
}

@keyframes fadeOut {
	0% {
		opacity: 1;
	}
	100% {
		opacity: 0;
	}
}

/****************************************************************************************************
    shortcode stuff
****************************************************************************************************/
/*
*/

.form-step-with
{
    max-width: 400px;
    margin-left: 0;
}

.form-step-with .input-number-container
{
    display: inline-block;
    vertical-align: top;
}

.form-step-with input[type="checkbox"] + button[type="toggle"] {
    display: inline;
    margin-top: 0;
}


.form-step-with ._column {
    display: inline-block;
    width: calc(100% - 120px);
    min-width: 200px;
    height: auto;
    min-height: inherit;
    padding: 0;
    background: none;
    border-radius: 0;
}

.form-step-with ._column + ._column {
    width: 120px;
    min-width: inherit;
    text-align: right;
}

.form-step .price-conversion
{
    display: inline-block;
    vertical-align: top;
    color: #999999;
    font-size: 16px;
    text-align: left;

    height: 30px;
    margin: 0;
    padding: 3px 10px;
}

._column2 .form-step-with .form-linked {
    margin-top: 10px;
}

/****************************************************************************************************
    real checkbox
****************************************************************************************************/

.form-step-checkbox
{
    display: block;
    width: 100%;
    margin-top: 6px;
    font-size: 0;
}

.form-step-checkbox input[type="checkbox"]
{
    display: inline-block;
}

.form-step-checkbox .checkbox-container
{
    vertical-align: middle;
    display: inline-block;
    text-align: center;
    width: 24px;
    font-size: 14px;
}

.form-step-checkbox .checkbox-label
{
    vertical-align: middle;
    display: inline-block;
    text-align: left;
    width: calc(100% - (24px + 5px));
	margin-left: 5px;
    background: none;
    box-shadow: none;
    font-size: 14px;
    vertical-align: top;
    text-overflow: ellipsis;
    color: #ffffff;
}

/****************************************************************************************************
    LOVENSE
****************************************************************************************************/

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"]
{
    width: 28px;
    height: 28px;
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"]:after
{
    --size: 18px;
    width: var(--size);
    height: var(--size);
    /*
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/lush2.svg');
    */
    background-size: var(--size) var(--size);
    background-repeat: no-repeat;
    background-position: center;
    border: 0;
    opacity: .25;
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"][data-value="lush"]:after
{
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/lush2.svg');
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"][data-value="nora"]:after
{
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/nora.svg');
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"][data-value="domi"]:after
{
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/domi.svg');
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"][data-value="hush"]:after
{
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/hush.svg');
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"][data-value="gemini"]:after
{
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/gemini.svg?20241003.1600');
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"][data-value="xmachine"]:after
{
    background-image: url('https://iptv.firestormmedia.tv/iframes/firecall-responsive/css/icons/xmachine.svg?20220810.1300');
}

.form-radio-item button[type="radio-toggle"][data-target^="lovense_type"] + label
{
    width: calc(100% - (28px + 8px));
    line-height: 16px;
    height: 28px;
}

.form-radio-item:hover input ~ button[type="radio-toggle"][data-target^="lovense_type"]:after,
.form-radio-item input:checked ~ button[type="radio-toggle"][data-target^="lovense_type"]:after,
.form-radio-item:hover input:checked ~ button[type="radio-toggle"][data-target^="lovense_type"]:after
{
    background-color: inherit;
    opacity: 1;
}

/****************************************************************************************************
    shortcode stuff
****************************************************************************************************/

.form-container label[for^="sortcode"] {
    display: block;
}

.form-container input[type="number"][name^="sortcode"] {
    width: 60px;
}

/****************************************************************************************************
    mobile
****************************************************************************************************/

@media only screen and (max-width: 800px) {

    .form-container {
        padding: 20px;
    }

}
