/* =========================================================
   REGISTER MEMBERSHIP PAGE
   Premium / Clean / Production Ready
   Full Replace - UI polish pass
========================================================= */

.register-page-shell{
    position:relative;
    min-height:100vh;
    padding:20px 18px 28px;
    background:linear-gradient(180deg,#f7f9fc 0%,#f2f5f9 100%);
}

.register-page-shell::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:220px;
    pointer-events:none;
    background:linear-gradient(180deg,rgba(255,255,255,.72) 0%,rgba(255,255,255,0) 100%);
}

.register-page-container{
    position:relative;
    z-index:1;
    width:100%;
    max-width:1380px;
    margin:0 auto;
}

.register-page-bar{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    padding:26px 30px 28px;
    margin-bottom:16px;
    border:1px solid #e3e9f1;
    border-radius:28px;
    background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
    box-shadow:0 18px 38px rgba(16,24,40,.045);
    overflow:hidden;
}

.register-page-bar::after{
    content:"";
    position:absolute;
    left:30px;
    top:0;
    width:92px;
    height:4px;
    border-radius:0 0 10px 10px;
    background:linear-gradient(90deg,#cfd9e6 0%,#9db0c9 100%);
}

.register-page-bar-main{
    min-width:0;
    flex:1 1 auto;
}

.register-page-kicker{
    display:inline-flex;
    align-items:center;
    min-height:30px;
    padding:0 14px;
    margin-bottom:12px;
    border:1px solid #dbe3ec;
    border-radius:999px;
    background:#f8fafc;
    color:#60728c;
    font-size:11px;
    font-weight:800;
    letter-spacing:.1em;
    text-transform:uppercase;
}

.register-page-title{
    margin:0;
    color:#182338;
    font-size:40px;
    line-height:1.03;
    font-weight:800;
    letter-spacing:-.03em;
}

.register-page-subtitle{
    max-width:760px;
    margin:12px 0 0;
    color:#66768a;
    font-size:15px;
    line-height:1.72;
}

.register-page-bar-tags,
.register-step-chips{
    display:none !important;
}

.register-card{
    background:linear-gradient(180deg,#ffffff 0%,#fcfdff 100%);
    border:1px solid #e5ebf2;
    border-radius:28px;
    box-shadow:0 18px 38px rgba(16,24,40,.045);
}

.register-card-form{
    padding:26px 30px 28px;
}

.register-card-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    margin-bottom:20px;
    padding-bottom:18px;
    border-bottom:1px solid #edf2f6;
}

.register-card-head-left{
    min-width:0;
}

.register-card-kicker{
    display:block;
    margin-bottom:6px;
    color:#637590;
    font-size:11px;
    font-weight:800;
    letter-spacing:.1em;
    text-transform:uppercase;
}

.register-card-title{
    margin:0;
    color:#182338;
    font-size:28px;
    line-height:1.12;
    font-weight:800;
    letter-spacing:-.02em;
}

.register-form{
    margin:0;
}

.register-membership-box,
.register-company-fields{
    margin-bottom:16px;
    padding:16px 18px 18px;
    border-radius:18px;
}

.register-membership-box{
    border:1px solid #e5ebf2;
    background:linear-gradient(180deg,#fbfcfe 0%,#f7f9fc 100%);
}

.register-company-fields{
    display:none;
    border:1px dashed #d2dce8;
    background:linear-gradient(180deg,#fcfdff 0%,#f8fafc 100%);
}

.register-company-fields.is-active{
    display:block;
}

.register-section-label{
    display:inline-flex;
    align-items:center;
    min-height:30px;
    padding:0 12px;
    margin-bottom:12px;
    border:1px solid #dce4ee;
    border-radius:999px;
    background:#eef3f8;
    color:#223149;
    font-size:11px;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
}

.register-membership-options{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
}

.register-membership-option{
    position:relative;
    display:flex;
    align-items:center;
    min-height:60px;
    padding:0 18px;
    border:1px solid #d9e2ec;
    border-radius:16px;
    background:#ffffff;
    transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease, transform .16s ease;
    cursor:pointer;
}

.register-membership-option:hover{
    border-color:#c0cfde;
    background:#ffffff;
    box-shadow:0 10px 20px rgba(15,23,42,.045);
    transform:translateY(-1px);
}

.register-membership-option.is-active{
    border-color:#a8bbd2;
    background:linear-gradient(180deg,#fbfdff 0%,#f3f7fb 100%);
    box-shadow:0 14px 24px rgba(15,23,42,.05);
}

.register-membership-option input[type="radio"]{
    position:absolute;
    opacity:0;
    pointer-events:none;
}

.register-membership-option label{
    position:relative;
    display:flex;
    align-items:center;
    width:100%;
    min-height:18px;
    margin:0;
    padding-left:34px;
    color:#223149;
    font-size:15px;
    font-weight:800;
    cursor:pointer;
}

.register-membership-option label::before{
    content:"";
    position:absolute;
    left:0;
    top:50%;
    width:20px;
    height:20px;
    border:2px solid #9eb0c5;
    border-radius:50%;
    background:#ffffff;
    transform:translateY(-50%);
    transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.register-membership-option label::after{
    content:"";
    position:absolute;
    left:5px;
    top:50%;
    width:10px;
    height:10px;
    border-radius:50%;
    background:#5f7aa2;
    transform:translateY(-50%) scale(0);
    transition:transform .18s ease;
}

.register-membership-option input[type="radio"]:checked + label::before{
    border-color:#657f9f;
    box-shadow:0 0 0 4px rgba(101,127,159,.12);
}

.register-membership-option input[type="radio"]:checked + label::after{
    transform:translateY(-50%) scale(1);
}

.register-grid{
    display:grid;
    grid-template-columns:repeat(12,minmax(0,1fr));
    gap:16px 18px;
}

.register-grid-company{
    gap:14px 16px;
}

.register-col-12{ grid-column:span 12; }
.register-col-8{ grid-column:span 8; }
.register-col-6{ grid-column:span 6; }
.register-col-5{ grid-column:span 5; }
.register-col-4{ grid-column:span 4; }
.register-col-3{ grid-column:span 3; }

.register-field{
    min-width:0;
}

.register-field label{
    display:block;
    margin-bottom:8px;
    color:#223149;
    font-size:12px;
    font-weight:800;
    letter-spacing:.02em;
}

.register-field .form-control,
.register-inline .form-control,
.iti input,
.iti .form-control,
.register-country-search,
.register-country-trigger{
    width:100%;
    height:50px;
    border:1px solid #d4deea;
    border-radius:14px;
    background:#ffffff;
    color:#182338;
    font-size:14px;
    box-shadow:none;
    transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease, transform .16s ease;
}

.register-field .form-control,
.register-inline .form-control,
.iti input,
.iti .form-control,
.register-country-search{
    padding:0 15px;
}

.register-field .form-control:hover,
.register-inline .form-control:hover,
.iti input:hover,
.iti .form-control:hover,
.register-country-search:hover,
.register-country-trigger:hover{
    border-color:#c4d0de;
}

.register-field .form-control:focus,
.register-inline .form-control:focus,
.iti input:focus,
.iti .form-control:focus,
.register-country-search:focus,
.register-country-picker.is-open .register-country-trigger,
.register-country-trigger:focus{
    border-color:#99aec7;
    box-shadow:0 0 0 4px rgba(99,124,160,.12);
    background:#ffffff;
    outline:none;
}

.register-field .form-control[readonly]{
    background:#f6f8fb;
    cursor:not-allowed;
}

.register-field input[type="number"]::-webkit-outer-spin-button,
.register-field input[type="number"]::-webkit-inner-spin-button{
    -webkit-appearance:none;
    margin:0;
}

.register-field input[type="number"]{
    -moz-appearance:textfield;
}

.register-inline{
    display:flex;
    align-items:stretch;
    gap:10px;
}

.register-inline .form-control{
    flex:1 1 auto;
}

.register-password-field{
    position:relative;
}

.register-password-field .form-control{
    padding-right:46px;
}

.register-field-icon{
    position:absolute;
    right:15px;
    top:44px;
    color:#6d7d92;
    cursor:pointer;
    font-size:14px;
    line-height:1;
}

.register-country-native{
    position:absolute !important;
    left:-9999px !important;
    width:1px !important;
    height:1px !important;
    opacity:0 !important;
    pointer-events:none !important;
}

.register-country-picker{
    position:relative;
}

.register-country-trigger{
    display:flex;
    align-items:center;
    gap:12px;
    padding:0 15px;
    text-align:left;
}

.register-country-trigger-flag,
.register-country-option-flag{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    justify-content:center;
    width:24px;
    min-width:24px;
    line-height:1;
    text-align:center;
}

.register-flag-image,
.register-flag-generic{
    display:block;
    width:20px;
    height:15px;
    border-radius:4px;
    overflow:hidden;
    box-shadow:0 0 0 1px rgba(15,23,42,.08);
    background-color:#eef2f6;
}

.register-flag-image{
    object-fit:cover;
    background:#eef2f6;
}

.register-flag-generic{
    position:relative;
    background:linear-gradient(180deg,#f5f8fc 0%,#e4edf8 100%);
}

.register-flag-generic::before{
    content:"";
    position:absolute;
    left:4px;
    top:2px;
    bottom:2px;
    width:2px;
    border-radius:2px;
    background:#95a8c0;
}

.register-flag-generic::after{
    content:"";
    position:absolute;
    left:6px;
    top:3px;
    width:10px;
    height:7px;
    border-radius:0 2px 2px 0;
    background:linear-gradient(180deg,#8fa7c5 0%,#6e88aa 100%);
    clip-path:polygon(0 0,100% 14%,84% 50%,100% 86%,0 100%);
}

.register-country-trigger-label{
    flex:1 1 auto;
    min-width:0;
    overflow:hidden;
    color:#182338;
    font-size:14px;
    font-weight:700;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.register-country-trigger-icon{
    flex:0 0 auto;
    color:#6d7d92;
    font-size:15px;
    transition:transform .18s ease;
}

.register-country-picker.is-open .register-country-trigger-icon{
    transform:rotate(180deg);
}

.register-country-panel{
    position:absolute;
    top:calc(100% + 10px);
    left:0;
    right:0;
    z-index:40;
    display:none;
    padding:12px;
    border:1px solid #dce5ee;
    border-radius:18px;
    background:#ffffff;
    box-shadow:0 24px 46px rgba(16,24,40,.10);
}

.register-country-picker.is-open .register-country-panel{
    display:block;
}

.register-country-search-wrap{
    margin-bottom:10px;
}

.register-country-options{
    max-height:280px;
    overflow:auto;
    padding-right:2px;
}

.register-country-options::-webkit-scrollbar{
    width:8px;
}

.register-country-options::-webkit-scrollbar-track{
    background:#f4f7fa;
    border-radius:999px;
}

.register-country-options::-webkit-scrollbar-thumb{
    background:#d1dbe8;
    border-radius:999px;
}

.register-country-option{
    display:flex;
    align-items:center;
    gap:10px;
    width:100%;
    min-height:44px;
    padding:0 12px;
    border:1px solid transparent;
    border-radius:12px;
    background:#ffffff;
    color:#1c2940;
    text-align:left;
    transition:border-color .18s ease, background-color .18s ease, box-shadow .18s ease, transform .16s ease;
}

.register-country-option + .register-country-option{
    margin-top:5px;
}

.register-country-option:hover{
    border-color:#d8e2ee;
    background:#f8fafc;
    transform:translateY(-1px);
}

.register-country-option.is-selected{
    border-color:#c1cfdf;
    background:#f4f8fc;
    box-shadow:inset 0 0 0 1px rgba(101,127,159,.10);
}

.register-country-option-label{
    flex:1 1 auto;
    min-width:0;
    overflow:hidden;
    font-size:13px;
    font-weight:700;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.register-country-option-code{
    flex:0 0 auto;
    color:#74859a;
    font-size:11px;
    font-weight:800;
    letter-spacing:.05em;
}

.register-btn-secondary,
.register-btn-light,
.register-submit-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:50px;
    padding:0 18px;
    border-radius:14px;
    font-size:13px;
    font-weight:800;
    letter-spacing:.015em;
    transition:transform .15s ease, box-shadow .2s ease, opacity .2s ease, background-color .2s ease, border-color .2s ease, color .2s ease;
    white-space:nowrap;
    outline:none;
}

.register-btn-secondary{
    min-width:132px;
    border:1px solid #1f2b44;
    background:#1f2b44;
    color:#ffffff;
    box-shadow:0 10px 18px rgba(31,43,68,.10);
}

.register-btn-secondary:hover{
    color:#ffffff;
    transform:translateY(-1px);
    box-shadow:0 14px 24px rgba(31,43,68,.14);
}

.register-btn-secondary:disabled{
    opacity:.62;
    cursor:not-allowed;
    transform:none;
    box-shadow:none;
}

.register-btn-light{
    min-width:112px;
    border:1px solid #ced8e4;
    background:#ffffff;
    color:#1f2b44;
}

.register-btn-light:hover{
    background:#f7f9fc;
    color:#1f2b44;
}

.register-btn-light:disabled{
    opacity:.62;
    cursor:not-allowed;
}

.register-verify-box{
    margin-top:10px;
    padding:12px;
    border:1px solid #e4ebf3;
    border-radius:16px;
    background:linear-gradient(180deg,#fbfcfe 0%,#f8fafc 100%);
}

.register-verify-message{
    display:block;
    margin-top:8px;
    min-height:18px;
    color:#67768c;
    font-size:11px;
    line-height:1.55;
}

.register-verify-success{
    display:none;
    margin-top:8px;
    color:#15803d;
    font-size:11px;
    font-weight:800;
}

.register-note-line,
.register-security-note{
    display:flex;
    align-items:center;
    gap:12px;
    flex-wrap:wrap;
    min-height:50px;
    padding:12px 14px;
    border-radius:16px;
}

.register-note-line{
    border:1px solid #e6ecf3;
    background:linear-gradient(180deg,#fbfcfe 0%,#f7f9fc 100%);
}

.register-note-line span{
    position:relative;
    padding-left:13px;
    color:#627389;
    font-size:12px;
    font-weight:600;
    line-height:1.6;
}

.register-note-line span::before{
    content:"";
    position:absolute;
    left:0;
    top:8px;
    width:5px;
    height:5px;
    border-radius:50%;
    background:#6b809e;
}

.register-consent-item{
    position:relative;
    padding:14px 16px 14px 42px;
    border:1px solid #e5ebf3;
    border-radius:16px;
    background:#ffffff;
    transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease, transform .16s ease;
}

.register-consent-item:hover{
    border-color:#d3dde8;
    background:#fbfcfd;
}

.register-consent-item.is-checked{
    border-color:#c2cfe0;
    background:linear-gradient(180deg,#fcfdff 0%,#f6f9fc 100%);
    box-shadow:0 14px 24px rgba(16,24,40,.04);
}

.register-consent-item-primary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
}

.register-consent-item-mini{
    flex:1 1 0;
    min-width:0;
}

.register-consent-input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}

.register-consent-label{
    position:relative;
    display:block;
    margin:0;
    color:#4f5e75;
    font-size:13px;
    line-height:1.6;
    font-weight:700;
    cursor:pointer;
}

.register-consent-label::before{
    content:"";
    position:absolute;
    left:-28px;
    top:2px;
    width:18px;
    height:18px;
    border:2px solid #c5d0dc;
    border-radius:5px;
    background:#ffffff;
}

.register-consent-label::after{
    content:"";
    position:absolute;
    left:-23px;
    top:7px;
    width:10px;
    height:5px;
    border-left:2px solid #ffffff;
    border-bottom:2px solid #ffffff;
    transform:rotate(-45deg) scale(0);
    transition:transform .18s ease;
}

.register-consent-input:checked + .register-consent-label::before{
    background:#1f2b44;
    border-color:#1f2b44;
}

.register-consent-input:checked + .register-consent-label::after{
    transform:rotate(-45deg) scale(1);
}

.register-consent-link{
    color:#1f2b44;
    font-weight:800;
    text-decoration:none;
    border-bottom:1px solid rgba(31,43,68,.24);
}

.register-consent-link:hover{
    color:#1f2b44;
    text-decoration:none;
    border-bottom-color:#1f2b44;
}

.register-consent-helper{
    margin-top:0;
    flex:0 0 auto;
}

.register-consent-helper a{
    color:#67768c;
    font-size:11px;
    font-weight:800;
    text-decoration:none;
    white-space:nowrap;
}

.register-consent-helper a:hover{
    color:#1f2b44;
    text-decoration:none;
}

.register-marketing-row{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}

.register-submit-wrap{
    margin-top:6px;
}

.register-submit-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    flex-wrap:wrap;
    padding-top:2px;
}

.register-login-text{
    color:#5f6f85;
    font-size:13px;
    line-height:1.6;
}

.register-login-text a{
    color:#1f2b44;
    font-weight:800;
    text-decoration:none;
    border-bottom:1px solid rgba(31,43,68,.24);
}

.register-login-text a:hover{
    color:#1f2b44;
    text-decoration:none;
    border-bottom-color:#1f2b44;
}

.register-submit-btn{
    min-width:236px;
    border:1px solid #1f2b44;
    background:#1f2b44;
    color:#ffffff;
    box-shadow:0 12px 20px rgba(31,43,68,.12);
}

.register-submit-btn:hover:not(:disabled){
    color:#ffffff;
    transform:translateY(-1px);
    box-shadow:0 16px 26px rgba(31,43,68,.16);
}

.register-submit-btn:disabled{
    opacity:.5;
    cursor:not-allowed;
    box-shadow:none;
    background:#8d97a6;
    border-color:#8d97a6;
}

.register-submit-btn-full{
    width:100%;
    min-width:0;
}

.iti{
    width:100%;
}

.iti__flag-container{
    z-index:5;
}

.iti__selected-flag{
    gap:8px;
    padding:0 10px 0 14px !important;
    border-right:1px solid #e7edf4;
    background:transparent !important;
}

.iti__flag-container:hover .iti__selected-flag,
.iti__flag-container:focus .iti__selected-flag,
.iti__flag-container:focus-within .iti__selected-flag{
    background:transparent !important;
}

.iti--separate-dial-code .iti__selected-dial-code{
    margin-left:0 !important;
    color:#4a5a72;
    font-size:14px;
    font-weight:700;
    letter-spacing:.01em;
}

.iti__arrow{
    margin-left:6px !important;
    border-top-color:#6d7d92 !important;
}

.iti__country-list{
    margin-top:10px;
    border:1px solid #dce5ee;
    border-radius:18px;
    background:#ffffff;
    box-shadow:0 24px 46px rgba(16,24,40,.10);
}

.iti__country{
    display:flex;
    align-items:center;
    min-height:44px;
    padding:0 12px;
    font-size:14px;
    color:#1c2940;
}

.iti__country.iti__highlight{
    background:#f4f7fb;
}

.iti__country-name,
.iti__dial-code{
    font-size:14px;
}

.iti__country-name{
    color:#1c2940;
}

.iti__dial-code{
    color:#6f8097;
}

.iti__flag-box{
    width:22px;
    min-width:22px;
    margin-right:10px !important;
}

.iti__selected-flag .iti__flag,
.iti__country .iti__flag{
    width:20px !important;
    height:15px !important;
    border-radius:4px;
    overflow:hidden;
    box-shadow:0 0 0 1px rgba(15,23,42,.08);
    background:none !important;
    background-image:none !important;
    background-color:#eef2f6 !important;
    display:flex;
    align-items:center;
    justify-content:center;
    position:relative;
    flex:0 0 20px;
}

.iti__selected-flag .iti__flag > .register-flag-image,
.iti__country .iti__flag > .register-flag-image,
.iti__selected-flag .iti__flag > .register-flag-generic,
.iti__country .iti__flag > .register-flag-generic{
    width:20px;
    height:15px;
    box-shadow:none;
    border-radius:4px;
}

.register-policy-modal .modal-content,
.register-status-modal .modal-content{
    border:0;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 24px 56px rgba(16,24,40,.14);
}

.register-policy-modal-header,
.register-policy-footer{
    border-color:#edf1f5;
}

.register-policy-modal-header{
    padding:22px 26px 16px;
    align-items:flex-start;
}

.register-policy-kicker{
    color:#61728b;
    font-size:12px;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
}

.register-policy-title{
    margin:8px 0 0;
    color:#182338;
    font-size:28px;
    font-weight:800;
    letter-spacing:-.02em;
}

.register-policy-subtitle{
    margin:10px 0 0;
    color:#67768c;
    font-size:13px;
    line-height:1.7;
}

.register-policy-close{
    margin-left:16px;
    color:#6b7a8f;
    opacity:1;
}

.register-policy-modal-body{
    padding:0 26px 26px;
}

.register-policy-shell{
    border:1px solid #e7edf3;
    border-radius:18px;
    overflow:hidden;
    background:#ffffff;
}

.register-policy-topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:14px 18px;
    border-bottom:1px solid #edf2f6;
    background:#f8fafc;
    color:#5f6f85;
    font-size:12px;
    line-height:1.6;
}

.register-policy-page-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:40px;
    padding:0 14px;
    border:1px solid #d7e0ea;
    border-radius:12px;
    background:#ffffff;
    color:#1f2b44;
    font-size:12px;
    font-weight:800;
    text-decoration:none;
    white-space:nowrap;
}

.register-policy-page-link:hover{
    background:#f7f9fc;
    color:#1f2b44;
    text-decoration:none;
}

.register-policy-scroll{
    max-height:62vh;
    overflow:auto;
    padding:20px 22px;
}

.register-policy-scroll::-webkit-scrollbar{
    width:10px;
}

.register-policy-scroll::-webkit-scrollbar-track{
    background:#f5f7fa;
}

.register-policy-scroll::-webkit-scrollbar-thumb{
    background:#d6dee8;
    border-radius:999px;
}

.register-policy-block + .register-policy-block{
    margin-top:24px;
    padding-top:20px;
    border-top:1px solid #edf2f6;
}

.register-policy-content h2{
    margin:0 0 10px;
    color:#1e2b42;
    font-size:18px;
    font-weight:800;
    letter-spacing:-.01em;
}

.register-policy-content p,
.register-policy-content li{
    color:#536278;
    font-size:13px;
    line-height:1.8;
}

.register-policy-content ul{
    margin:10px 0 0;
    padding-left:18px;
}

.register-policy-content a{
    color:#1f2b44;
    font-weight:700;
    text-decoration:underline;
    text-underline-offset:2px;
}

.register-policy-footer{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:16px 26px 22px;
    background:#ffffff;
}

.register-policy-footer-text{
    color:#67768c;
    font-size:12px;
    line-height:1.6;
}

.register-status-modal-content{
    position:relative;
}

.register-status-close{
    position:absolute;
    top:10px;
    right:14px;
    color:#182338;
    opacity:1;
    z-index:2;
}

.register-status-body{
    padding:26px 22px 16px;
    text-align:center;
    background:#ffffff;
}

.register-status-icon{
    display:block;
    margin-bottom:8px;
    color:#5b7aa3;
    font-size:44px;
}

.register-status-title{
    margin-bottom:10px;
    color:#1f2b44;
    font-size:21px;
    font-weight:800;
}

.register-status-text{
    color:#5f6f85;
    font-size:14px;
    line-height:1.7;
}

.register-status-footer{
    padding:0 18px 18px;
    background:#ffffff;
}

.register-spin{
    width:14px;
    height:14px;
    border:2px solid rgba(255,255,255,.45);
    border-top-color:#ffffff;
    border-radius:50%;
    animation:register-spin-key .8s linear infinite;
}

@keyframes register-spin-key{
    to{ transform:rotate(360deg); }
}

.register-password-panel{
    display:none;
    padding:14px 16px;
    border:1px solid #e5ebf3;
    border-radius:16px;
    background:linear-gradient(180deg,#fbfcfe 0%,#f7f9fc 100%);
}

.register-password-panel.is-engaged{
    display:block;
}

.register-password-feedback,
.register-password-match{
    font-size:12px;
    line-height:1.6;
    font-weight:700;
}

.register-password-feedback{
    color:#66778f;
}

.register-password-feedback.is-error,
.register-password-match.is-error{
    color:#c2410c;
}

.register-password-feedback.is-success,
.register-password-match.is-success{
    color:#15803d;
}

.register-password-rules{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-top:10px;
}

.register-password-rule{
    display:inline-flex;
    align-items:center;
    min-height:30px;
    padding:0 11px;
    border:1px solid #d8e2ee;
    border-radius:999px;
    background:#ffffff;
    color:#6b7c91;
    font-size:11px;
    font-weight:800;
    letter-spacing:.01em;
    transition:border-color .18s ease, background-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.register-password-rule::before{
    content:"•";
    margin-right:6px;
    font-size:12px;
    line-height:1;
}

.register-password-rule.is-ok{
    border-color:#b9e3c5;
    background:#effaf2;
    color:#166534;
}

.register-password-rule.is-ok::before{
    content:"✓";
}

.register-password-rule.is-bad{
    border-color:#f3c7b3;
    background:#fff7f3;
    color:#c2410c;
}

.register-password-match{
    min-height:18px;
    margin-top:10px;
}

.register-field .form-control.is-invalid,
.register-country-trigger.is-invalid{
    border-color:#ef8f73 !important;
    box-shadow:0 0 0 4px rgba(239,143,115,.12) !important;
}

.register-field .form-control.is-valid,
.register-country-trigger.is-valid{
    border-color:#8fca9e !important;
    box-shadow:0 0 0 4px rgba(143,202,158,.12) !important;
}

.register-honeypot{
    position:absolute !important;
    left:-99999px !important;
    top:auto !important;
    width:1px !important;
    height:1px !important;
    overflow:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
}

.register-honeypot label,
.register-honeypot input{
    display:block !important;
    width:1px !important;
    height:1px !important;
    min-width:1px !important;
    min-height:1px !important;
    margin:0 !important;
    padding:0 !important;
    border:0 !important;
    background:transparent !important;
    color:transparent !important;
    font-size:0 !important;
    line-height:0 !important;
}

.register-security-note{
    border:1px dashed #d8e2ed;
    background:linear-gradient(180deg,#fbfcfe 0%,#f6f9fc 100%);
}

.register-security-note-icon{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:22px;
    height:22px;
    border-radius:999px;
    background:#eef3f8;
    color:#5d7393;
    font-size:11px;
}

.register-security-note-text{
    color:#617289;
    font-size:12px;
    font-weight:700;
    line-height:1.6;
    letter-spacing:.01em;
}

@media (max-width:1399px){
    .register-page-title{
        font-size:34px;
    }
}

@media (max-width:1199px){
    .register-page-container{
        max-width:1160px;
    }

    .register-page-bar,
    .register-card-form{
        padding-left:24px;
        padding-right:24px;
    }

    .register-page-bar{
        flex-direction:column;
        align-items:flex-start;
    }

    .register-card-title{
        font-size:25px;
    }
}

@media (max-width:991px){
    .register-page-shell{
        padding:12px 10px 18px;
    }

    .register-page-bar,
    .register-card{
        border-radius:22px;
    }

    .register-page-bar{
        padding:20px 18px 22px;
    }

    .register-page-title{
        font-size:28px;
    }

    .register-page-subtitle{
        font-size:14px;
    }

    .register-card-form{
        padding:18px;
    }

    .register-card-head{
        flex-direction:column;
        align-items:flex-start;
    }

    .register-card-title{
        font-size:24px;
    }

    .register-grid,
    .register-grid-company{
        grid-template-columns:1fr;
        gap:14px;
    }

    .register-col-12,
    .register-col-8,
    .register-col-6,
    .register-col-5,
    .register-col-4,
    .register-col-3{
        grid-column:auto;
    }

    .register-consent-item-primary{
        flex-direction:column;
        align-items:flex-start;
    }

    .register-marketing-row{
        flex-direction:column;
    }

    .register-submit-btn{
        width:100%;
        min-width:0;
    }

    .register-submit-row{
        flex-direction:column;
        align-items:stretch;
    }
}

@media (max-width:767px){
    .register-membership-options{
        grid-template-columns:1fr;
    }

    .register-inline,
    .register-policy-topbar,
    .register-policy-footer,
    .register-note-line{
        flex-direction:column;
        align-items:stretch;
    }

    .register-btn-secondary,
    .register-btn-light,
    .register-policy-page-link{
        width:100%;
        min-width:0;
    }

    .register-field-icon{
        top:44px;
    }

    .register-country-panel{
        padding:10px;
    }
}

@media (max-width:576px){
    .register-page-shell{
        padding:8px 6px 14px;
    }

    .register-page-bar,
    .register-card{
        border-radius:18px;
    }

    .register-page-bar,
    .register-card-form{
        padding-left:14px;
        padding-right:14px;
    }

    .register-page-title{
        font-size:24px;
    }

    .register-card-title{
        font-size:20px;
    }

    .register-policy-title{
        font-size:22px;
    }

    .register-policy-modal-header,
    .register-policy-modal-body,
    .register-policy-footer{
        padding-left:16px;
        padding-right:16px;
    }

    .register-policy-scroll{
        max-height:58vh;
        padding:14px 16px;
    }

    .register-country-option{
        min-height:42px;
    }
}
