/* Auth page shared styles */
body {
    background: #f7f8fa !important;
}
.register-wrapper, .complete-registration-wrapper {
    margin: 20px;
}

.register-wrapper .register-left, .register-wrapper .register-right, .register-wrapper .card {
    border-radius: 32px;
    height: 100%;
}
.register-left {
    background: #006666;
    color: #fff;
    justify-content: center;
    align-items: center;
    padding: 20px;
}
.register-left img {
    padding: 20px;
}
.register-left h2 {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 16px;
}
.register-left p {
    font-size: 1.1rem;
    opacity: 0.85;
    margin-bottom: 0;
}
.register-right {
    background: #fff;
    flex-direction: column;
    align-items: center;
    padding: 20px 20px;
}
.register-right .iti, .complete-registration-wrapper .iti {
    width: 100%;
}
.register-card {
    width: 100%;
    max-width: 400px;
    background: #fff;
    border-radius: 16px;
    padding: 32px 24px;
    margin: 0 auto;
}
.register-logo {
    display: block;
    margin: 0 auto 24px auto;
    max-width: 180px;
}
.register-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 8px;
    text-align: left;
    color: #151515;
}
.register-desc {
    font-size: 1rem;
    color: #666;
    text-align: left;
    margin-bottom: 24px;
}
.register-btn, .btn-primary {
    width: 100%;
    background: #006666;
    color: #fff;
    font-weight: 600;
    border-radius: 8px;
    padding: 12px;
    border: none;
    font-size: 1rem;
    margin-top: 16px;
    transition: background 0.2s;
}
.register-btn:hover, .btn-primary:hover {
    background: #145e50;
}
.register-link {
    display: block;
    text-align: center;
    margin-top: 18px;
    color: #006666;
    font-weight: 500;
    text-decoration: underline;
}
.alert {
    margin-bottom: 16px;
    padding: 12px;
    border-radius: 8px;
    font-size: 1rem;
}
.alert-success { background: #e6f7ee; color: #006666; }
.alert-danger { background: #ffeaea; color: #c0392b; }
.p-20 {
    padding: 20px !important;
}
.p-25 {
    padding: 25px !important;
}
.fw-700 {
    font-weight: 700 !important;
}
.step-indicator {
    border-bottom: 2px solid #e9ecef;
    margin-bottom: 2rem;
}

.steps-container {
    display: flex;
    gap: 0;
}

.step {
    flex: 1;
    padding: 1rem 0.5rem;
    text-align: center;
    font-size: 14px;
    color: #6c757d;
    border-bottom: 3px solid transparent;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    font-weight: bold;
}

.step:hover {
    color: #495057;
}

.step.active {
    color: #1b6e6e;
    font-weight: bolder;
    border-bottom: 4px solid;
    border-radius: 2px;
}

.step.completed {
    color: #28a745;
    border-bottom-color: #28a745;
    font-weight: bolder;
    border-bottom: 4px solid;
    border-radius: 2px;
}

.step-content {
    display: none;
    animation: fadeIn 0.3s ease-in;
    overflow-y: auto;
    overflow-x: hidden;
    padding-left: 10px;
    padding-right: 10px;
    max-height: 310px;
    min-height: 310px;
}

.step-content.active {
    display: block;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
.complete-registration-wrapper #nextBtn, .complete-registration-wrapper #nextBtnBottom, .complete-registration-wrapper #skipBtnBottom, .complete-registration-wrapper #submitBtn {
    border-radius: 7px !important;
    width: 170px;
    font-size: 15px !important;
}
.complete-registration-wrapper #skipBtn {
    border-radius: 7px !important;
    width: 170px !important;
    font-size: 15px !important;
}
.btn-primary-outline {
    width: 100%;
    background: #fff;
    color: #006666;
    font-weight: 600;
    border-radius: 8px;
    padding: 12px;
    border: 1px solid #006666;
    font-size: 1rem;
    margin-top: 16px;
    transition: background 0.2s;
}
.btn-primary-outline:hover, .btn-primary:hover {
    background: #145e50;
    color: #fff;
}
.btn-primary:active {
    background: #145e50 !important;
    color: #fff !important;
}
.btn-outline-secondary {
    background: #fff;
    color: #495057;
    font-weight: 600;
    border-radius: 8px;
    padding: 12px;
    border: 1px solid #495057;
    font-size: 1rem;
    margin-top: 16px;
    transition: background 0.2s;
}
.btn-outline-secondary:hover {
    background: #495057;
    color: #fff;
}
#shifts-tabs .nav-item .nav-link {
    border-radius: 8px !important;
    border: 1px solid #006666 !important;
    color: #006666 !important;
    font-weight: 600 !important;
}
#shifts-tabs .nav-item .nav-link.active {
    background-color: #006666 !important;
    color: #fff !important;
}
#shifts-tabs li {
    margin:2px;
}
@media (max-width: 768px) {
    .steps-container {
        overflow-x: auto;
        white-space: nowrap;
        gap: 16px;
        scrollbar-width: none; /* Firefox */
    }

    .steps-container::-webkit-scrollbar {
        display: none; /* Chrome */
    }

    .step {
        flex-shrink: 0;
    }
    .complete-registration-wrapper #skipBtnBottom, .complete-registration-wrapper #nextBtnBottom {
        width: 100px !important;
    }
    .custom-control-label {
        font-size: 12px !important;
    }
    #shifts-content .input-group .input-group-text {
        display: none !important;
    }
    #shifts-content .input-group .form-control {
        font-size: 12px !important;
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
    }

}