/* ===============================
   Base
=================================*/
body {
    background-color: #f4f7fa;
    color: #333;
    font-family: "Inter Tight", sans-serif;
    line-height: 1.5;
}

@media (max-width: 640px) {
    main {
        padding: 24px 16px;
    }
}

* {
    font-family: "Inter Tight", sans-serif;
}

p {
    font-size: 14px;
}

/* ===============================
   Scoped Webform Styles
=================================*/

/* Typography */
.webform-submission-artist-registration-form-form h1,
.webform-submission-artist-registration-form-form h2,
.webform-submission-artist-registration-form-form h3,
.webform-submission-artist-registration-form-form h4,
.webform-submission-artist-registration-form-form h5,
.webform-submission-artist-registration-form-form h6 {
    font-family: 'Nohemi';
    line-height: 1.2;
}

/* ===============================
   Form Container
=================================*/
.webform-submission-artist-registration-form-form .webform-progress-tracker {
    font-family: 'Nohemi';
}

.webform-submission-artist-registration-form-form .progress-marker::before,
.webform-submission-artist-registration-form-form .progress-title {
    font-size: 14px;
    padding-bottom: 0;
}

.webform-submission-artist-registration-form-form .progress-step .progress-marker .step-title {
    color: #000;
    font-size: 12px;
    transform: translateY(10px);
    display: block;
}

@media(max-width: 767px){
    .webform-submission-artist-registration-form-form .progress-step .progress-marker .step-title {
        display: none;
    }
}

.webform-submission-artist-registration-form-form .progress-step.is-active .progress-marker .step-title {
    color: #2e9aff;
    font-weight: 600;
}

/* ===============================
   Layout
=================================*/
.webform-submission-artist-registration-form-form .content-container {
    display: flex;
    gap: 16px;
}

.webform-submission-artist-registration-form-form .content-container .form-item {
    flex: 1;
}

@media (max-width: 640px) {
    .webform-submission-artist-registration-form-form .content-container {
        flex-direction: column;
    }
}

/* ===============================
   Labels & Descriptions
=================================*/
.webform-submission-artist-registration-form-form label,
.webform-submission-artist-registration-form-form .fieldset-legend {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 6px;
    display: block;
}

.webform-submission-artist-registration-form-form label.form-required::after {
    content: "*";
    color: #d10202;
    margin-left: 4px;
}

.webform-submission-artist-registration-form-form .description {
    font-size: 12px;
    color: #666;
    margin: 4px 0 14px;
    margin-top: -12px;
}


.hidden-field .js-form-item{
    display: none;
}

/* ===============================
   Inputs
=================================*/
input[type="text"], 
input[type="date"], 
input[type="tel"], 
input[type="number"], 
input[type="email"], 
input[type="password"], 
textarea, 
select{
    width: 100%;
    padding: 14px;
    margin-bottom: 20px;
    border: 1px solid #d6d6d6;
    border-radius: 8px;
    font-size: 14px;
    background: #fff;
    transition: all 0.2s ease;
    box-sizing: border-box;
}

textarea {
    min-height: 120px;
}

input:focus,
textarea:focus,
select:focus {
    border-color: #2e9aff;
    box-shadow: 0 0 0 3px rgba(46,154,255,0.15);
    outline: none;
}

input::placeholder,
textarea::placeholder,
select::placeholder {
    font-size: 14px;
    font-family: "Inter Tight", sans-serif;
}

.webform-submission-artist-registration-form-form .iti--allow-dropdown {
    width: 100%;
}

/* Select2 */
.webform-submission-artist-registration-form-form .select2-container {
    margin-bottom: 20px;
    font-size: 12px;
}

.webform-submission-artist-registration-form-form .select2-container--default .select2-selection--multiple {
    border-radius: 8px !important;
    border: 1px solid #d6d6d6 !important;
    padding: 6px;
    min-height: 46px !important;
}

.select2-results__option[aria-selected] {
    font-size: 14px;
}

/* ===============================
   Buttons
=================================*/
.webform-submission-artist-registration-form-form button,
.webform-submission-artist-registration-form-form input[type="submit"] {
    font-family: "Inter Tight", sans-serif;
    background-color: #2e9aff;
    color: #fff;
    border: none;
    padding: 14px 24px;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.webform-submission-artist-registration-form-form button:hover,
.webform-submission-artist-registration-form-form input[type="submit"]:hover {
    background-color: #1a7dbd;
    transform: translateY(-2px);
}

.webform-submission-artist-registration-form-form button:active,
.webform-submission-artist-registration-form-form input[type="submit"]:active {
    transform: translateY(0);
}

.webform-submission-artist-registration-form-form .form-actions,
.webform-submission-artist-registration-form-form .wizard-navigation {
    display: flex;
    justify-content: flex-end;
    margin-top: 32px;
    gap: 12px;
}

@media (max-width: 640px) {
    .webform-submission-artist-registration-form-form .wizard-navigation {
        flex-direction: column;
    }

    .webform-submission-artist-registration-form-form .webform-container {
        padding: 20px;
    }
}

/* ===============================
   Composite Field
=================================*/
.webform-submission-artist-registration-form-form .form-type-webform-custom-composite {
    margin-bottom: 20px;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table {
    width: 100%;
    background: #f7f9fc;
    padding: 16px;
    border-radius: 12px;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite thead th {
    font-size: 13px;
    padding-bottom: 12px;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite tbody td {
    padding: 8px 0;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite  fieldset {
    margin: 0;
}

.webform-submission-artist-registration-form-form .webform-multiple-add,
.webform-submission-artist-registration-form-form .tabledrag-toggle-weight-wrapper {
    display: none;
}


.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table td.webform-multiple-table--operations {
    position: relative;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table td.webform-multiple-table--operations input:last-child {
    opacity: 0 !important;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table td.webform-multiple-table--operations:after {
    content: "";
    width: 20px;
    height: 20px;
    position: absolute;
    bottom: 50%;
    transform: translateY(32%);
    right: 7px;
    background: url(../../images/icon-bin.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    pointer-events: none;
    opacity: 0.4;
}

.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table td.webform-multiple-table--operations input:hover,
.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table td.webform-multiple-table--operations input:active,
.webform-submission-artist-registration-form-form .form-type-webform-custom-composite table td.webform-multiple-table--operations input:focus
{
    opacity: 0.4
}

@media (max-width: 640px) {
    .webform-submission-artist-registration-form-form .form-type-webform-custom-composite table tr,
    .webform-submission-artist-registration-form-form .webform-multiple-table-responsive td {
        display: block;
    }
}

/* ===============================
   Radios and Checkbox
=================================*/
.webform-submission-artist-registration-form-form .js-form-type-radio,
.webform-submission-artist-registration-form-form .js-form-type-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
}

.webform-submission-artist-registration-form-form .js-form-type-radio input,
.webform-submission-artist-registration-form-form .js-form-type-checkbox input {
    margin: 0;
}

.webform-submission-artist-registration-form-form .webform-entity-radios--wrapper .fieldset-wrapper,
.webform-submission-artist-registration-form-form .webform-entity-checkboxes--wrapper .fieldset-wrapper {
    margin-bottom: 20px;
}

.webform-submission-artist-registration-form-form .js-form-type-radio label,
.webform-submission-artist-registration-form-form .js-form-type-checkbox label {
    margin-bottom: 0;
    font-weight: 400;
}


/* ===============================
   Markup Section
=================================*/
.webform-submission-artist-registration-form-form .form-type-webform-markup:not(.talent_recorder) {
    border-bottom: 2px solid #2e9aff;
    margin: 40px 0 24px;
    padding-bottom: 8px;
}

.webform-submission-artist-registration-form-form .form-type-webform-markup h1,
.webform-submission-artist-registration-form-form .form-type-webform-markup h2,
.webform-submission-artist-registration-form-form .form-type-webform-markup h3,
.webform-submission-artist-registration-form-form .form-type-webform-markup h4,
.webform-submission-artist-registration-form-form .form-type-webform-markup h5,
.webform-submission-artist-registration-form-form .form-type-webform-markup h6
 {
    margin-bottom: 0px;
}

.webform-submission-artist-registration-form-form .form-type-webform-markup p {
    font-size: 14px;
    margin-bottom: 8px;
    margin-top: 0px;
}

/* ===============================
   Address Field
=================================*/
.webform-submission-artist-registration-form-form .address--wrapper .fieldset-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.webform-submission-artist-registration-form-form .address--wrapper .js-form-wrapper,
.webform-submission-artist-registration-form-form .address--wrapper .fieldset-wrapper > .js-form-item {
    width: calc(50% - 8px);
}

.webform-submission-artist-registration-form-form .address--wrapper .form-wrapper[data-drupal-selector="edit-address-country-code"]{
    order: 0;
}

.webform-submission-artist-registration-form-form .address--wrapper .js-form-item.form-item-address-administrative-area{
    order: 1;
}

.webform-submission-artist-registration-form-form .address--wrapper .js-form-item.form-item-address-address-line1{
    width: 100%;
    order: 2;
}

.webform-submission-artist-registration-form-form .address--wrapper .js-form-item.form-item-address-locality{
    order: 3;
}

.webform-submission-artist-registration-form-form .address--wrapper .js-form-item.form-item-address-postal-code{
    order: 4;
}

.webform-submission-artist-registration-form-form .address--wrapper .address-container-inline {
    display: none;
}

@media (max-width: 640px) {
    .webform-submission-artist-registration-form-form .address--wrapper .form-wrapper,
    .webform-submission-artist-registration-form-form .address--wrapper .js-form-item {
        width: 100%;
    }
}

/* ===============================
   Image Upload
=================================*/
.webform-submission-artist-registration-form-form .form-type-webform-image-file .js-webform-image-file {
    background: #f7f9fc;
    padding: 16px;
    border-radius: 12px;
}

.webform-submission-artist-registration-form-form .form-type-webform-image-file .js-form-item {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 10px 0;
}

.webform-submission-artist-registration-form-form .form-type-webform-image-file input[name="photoshoots_remove_button"] {
    padding: 6px 14px;
    font-size: 12px;
}

/* ===============================
   Alerts / Errors
=================================*/
.webform-submission-artist-registration-form-form div[role="alert"] {
    font-size: 14px;
    background: #fff1f1;
    border: 1px solid #ffcaca;
    padding: 16px;
    border-radius: 10px;
    margin-bottom: 16px;
}

.webform-submission-artist-registration-form-form div[role="alert"] ul {
    margin: 0;
    padding-left: 18px;
}

.webform-submission-artist-registration-form-form .webform-container .error-message {
    color: #ff4d4d;
}

/* ===============================
   Confirmation
=================================*/
.webform-submission-artist-registration-form-form .webform-confirmation {
    text-align: center;
    padding: 40px 0;
}

.webform-submission-artist-registration-form-form .webform-confirmation__message {
    font-family: 'Nohemi';
    font-size: 18px;
}


.webform-submission-artist-registration-form-form .form-type-webform-custom-composite .description,
.webform-submission-artist-registration-form-form .form-type-webform-image-file .description {
    margin-top: 0;
}


.trigger-other-race-target.v-none {
    visibility: hidden;
}

.js-webform-select-other .js-webform-select-other-input {
    margin-top: -13px !important;
}


.tr-recorder {
    width: auto;
    background: #f7f9fc;
    padding: 16px;
    border-radius: 12px;
    margin-bottom: 24px;
}
.tr-btn  {
    padding: 8px 24px !important;
    font-size: 14px !important;
}
.tr-controls { display: flex; gap: .5rem; margin: .75rem 0; }
.tr-btn:disabled { background: #aaa !important; cursor: not-allowed; }
.tr-record { background: #d9534f !important; }
.tr-stop   { background: #333 !important; }
.tr-timer  { font-size: 16px; font-weight: bold; letter-spacing: 2px; }
.tr-playback audio { width: 100%; margin-top: .5rem; }
.tr-upload-status { margin-top: .4rem; font-size: .85rem; color: #555; }
.tr-status {
    font-size: 14px;
}